_setServerPlugins(); } /** * Index action * * @return void */ public function indexAction() { include 'libraries/server_common.inc.php'; $header = $this->response->getHeader(); $scripts = $header->getScripts(); $scripts->addFile('vendor/jquery/jquery.tablesorter.js'); $scripts->addFile('server_plugins.js'); /** * Displays the page */ $this->response->addHTML( Template::get('server/sub_page_header')->render([ 'type' => 'plugins', ]) ); $this->response->addHTML($this->_getPluginsHtml()); } /** * Sets details about server plugins * * @return void */ private function _setServerPlugins() { $sql = "SELECT plugin_name, plugin_type, (plugin_status = 'ACTIVE') AS is_active, plugin_type_version, plugin_author, plugin_description, plugin_license FROM information_schema.plugins ORDER BY plugin_type, plugin_name"; $res = $this->dbi->query($sql); $this->plugins = array(); while ($row = $this->dbi->fetchAssoc($res)) { $this->plugins[$row['plugin_type']][] = $row; } $this->dbi->freeResult($res); ksort($this->plugins); } /** * Returns the html for plugin Tab. * * @return string */ private function _getPluginsHtml() { $html = '