On Fri, Aug 8, 2014 at 12:37 AM, Marc Delisle <marc@infomarc.info> wrote:
Ashutosh Dhundhara a écrit :
> On Wed, Aug 6, 2014 at 2:46 AM, Marc Delisle <marc@infomarc.info> wrote:
>
>> Le 2014-08-05 14:35, Ashutosh Dhundhara a écrit :
>>> Hi,
>>>
>>> I was starting to work on RFE #1123
>>> <https://sourceforge.net/p/phpmyadmin/feature-requests/1123/> (Zeroconf
>>> PMA tables support).
>>>
>>> Is it something like enabling/disabling the PMA configuration storage
>>> feature through UI with default table names?
>>>
>>> Also, automatically create these tables when user has enabled this
>>> feature through UI?
>> Hi Ashutosh,
>>
>
> Thanks Marc and Isaac.
>
> The RFE was a bit confusing but the insight provided by you both clarified
> everything.
> However, I have a few queries and I am posting them in-line.
>
>
>> I have read again the RFE and the comments in the ticket; then I read
>> the details of your proposal on google-melange.com.
>>
>> I don't have all the answers but can give you some pointers; others can
>> give ideas too or contradict mine :)
>>
>> * The solution has to work for a single-user installation and also for a
>> multi-user installation
>>
>
> How single-user and multi-user installation is going to affect this feature?
> Is it something like if the user does not have access to the database
> defined in the
> directive $cfg['Servers'][$i]['pmadb'], then create the pma tables in the
> database on which he/she
> has access?

It is current for a single-user installation to not bother creating a
control user; when there is no control user, the logged-in user is used
also to access the pmadb.

In a multi-user installation, there is normally a distinct control user
defined.

So please test both situations.

>
>
>> * Priority should go to use the values from config.inc.php (the control
>> user, pmadb and all pmadb tables) if present. This is mainly for
>> backward compatibility and also because I suspect it's the only way to
>> support a multi-user installation
>>
>> * In case there is no such configuration, the logic could check the
>> presence of the default database name and table names, as suggested in
>> examples/create_tables.sql
>>
>> * I'm not sure on which panel is the best place to do this verification,
>> but it could be at the same places where the warnings about the
>> configuration storage are currently done (home page and each database >
>> Operations page
>>
>> * If this default database name "phpmyadmin" does not exist, the logic
>> could look for the default table names in the current database (this is
>> in case the user has access to only one database)
>
>
> Lets say user sees the warning on homepage. Then how to decide the current
> db?

Good question; so probably the verification won't be possible from the
home page, only from a db-specific Operations page.

Anyway, we could not ask the user to choose a db to store the
configuration storage, because this choice could not be remembered (as
this is a zero-conf mechanism).

> Is it something like creating these tables in the first database on which
> the user has CREATE access?

No, because it won't be possible to know which db contains the
configuration storage, when the user opens another database.

>
>
>> * If the default db and/or default table names are not found, the logic
>> could pop a dialog, offering to create these in the current db and
>> asking for confirmation; I hope it's possible to directly read
>> examples/create_tables.sql for this, in order to avoid discrepancies
>> between the logic and changes in create_tables.sql
>>
>> * Something will have to be done with the logic that gives a warning
>> about the configuration storage; it would probably lose its purpose
>>
>
> Yes Marc. We will have to do something for this.
> How about keeping this message/warning intact and when the user clicks on
> 'here' of "To find out why click here
> <http://127.0.0.1/pma/chk_rel.php?token=ee04c7e45192bb15a4151248028e905f>.",
> the user
> will be directed to diagnostic page as it is currently done. And on that
> page we can provide a link with text something like "Fix it" and when user
> will click this link, the new logic will be executed?

Good idea. This way, either the user can fix it manually (in a way that
permits to have just one configuration storage) but will require
configuration, or will be able to use the zero-conf mechanism (which
will produce the pma_ tables in his current db).
>
>
>> * Maybe we'll need a new directive in config.inc.php, so that the
>> installer can decide that the zero conf is active or not (would be
>> active by default)
>>
>> * I am not in favor of designing a UI to set up the configuration
>> storage, as this already exists in /setup (with the goal of producing a
>> config.inc.php)
>>
>> * I am not in favor of programmatically creating a .php file in the
>> installation directory or doing any modification in config.inc.php


Hi Marc,

What if a user has access to multiple databases and the default database 'phpmyadmin' does not exists?
Lets say the user visits database 1 > Operation tab where he agrees to the choice to create pma tables in that database.

Now for the current session the configuration storage is up and working. Now when next time he logs into PMA, there will be again a warning for configuration storage on home page. But when he will visit database 1 > Operation tab, everything will become fine again.

But what if he visits database 2 > Operation tab before database 1. He will get a choice to create pma tables in that database too. If he agrees to create then there will be two different sets of pma tables because pmadb name can't be remembered.
What should be done in this case?



--
Ashutosh Dhundhara