| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 | <?phpdeclare(strict_types=1);namespace PhpMyAdmin\Server;use PhpMyAdmin\DatabaseInterface;use function __;class Plugins{    /** @var DatabaseInterface */    private $dbi;    /**     * @param DatabaseInterface $dbi DatabaseInterface instance     */    public function __construct(DatabaseInterface $dbi)    {        $this->dbi = $dbi;    }    /**     * @return Plugin[]     */    public function getAll(): array    {        global $cfg;        $sql = 'SHOW PLUGINS';        if (! $cfg['Server']['DisableIS']) {            $sql = 'SELECT * FROM information_schema.PLUGINS ORDER BY PLUGIN_TYPE, PLUGIN_NAME';        }        $result = $this->dbi->query($sql);        $plugins = [];        while ($row = $result->fetchAssoc()) {            $plugins[] = $this->mapRowToPlugin($row);        }        return $plugins;    }    /**     * @return array<int|string, string>     */    public function getAuthentication(): array    {        $result = $this->dbi->query(            'SELECT `PLUGIN_NAME`, `PLUGIN_DESCRIPTION` FROM `information_schema`.`PLUGINS`'                . ' WHERE `PLUGIN_TYPE` = \'AUTHENTICATION\';'        );        $plugins = [];        while ($row = $result->fetchAssoc()) {            $plugins[$row['PLUGIN_NAME']] = $this->getTranslatedDescription($row['PLUGIN_DESCRIPTION']);        }        return $plugins;    }    private function getTranslatedDescription(string $description): string    {        // mysql_native_password        if ($description === 'Native MySQL authentication') {            return __('Native MySQL authentication');        }        // sha256_password        if ($description === 'SHA256 password authentication') {            return __('SHA256 password authentication');        }        // caching_sha2_password        if ($description === 'Caching sha2 authentication') {            return __('Caching sha2 authentication');        }        // auth_socket || unix_socket        if ($description === 'Unix Socket based authentication') {            return __('Unix Socket based authentication');        }        // mysql_old_password        if ($description === 'Old MySQL-4.0 authentication') {            return __('Old MySQL-4.0 authentication');        }        return $description;    }    /**     * @param array $row Row fetched from database     */    private function mapRowToPlugin(array $row): Plugin    {        return Plugin::fromState([            'name' => $row['PLUGIN_NAME'] ?? $row['Name'],            'version' => $row['PLUGIN_VERSION'] ?? null,            'status' => $row['PLUGIN_STATUS'] ?? $row['Status'],            'type' => $row['PLUGIN_TYPE'] ?? $row['Type'],            'typeVersion' => $row['PLUGIN_TYPE_VERSION'] ?? null,            'library' => $row['PLUGIN_LIBRARY'] ?? $row['Library'] ?? null,            'libraryVersion' => $row['PLUGIN_LIBRARY_VERSION'] ?? null,            'author' => $row['PLUGIN_AUTHOR'] ?? null,            'description' => $row['PLUGIN_DESCRIPTION'] ?? null,            'license' => $row['PLUGIN_LICENSE'] ?? $row['License'],            'loadOption' => $row['LOAD_OPTION'] ?? null,            'maturity' => $row['PLUGIN_MATURITY'] ?? null,            'authVersion' => $row['PLUGIN_AUTH_VERSION'] ?? null,        ]);    }}
 |