*/ require_once('lib/debug/debugger-ext.php'); /** * \brief Show current permissions in a convenient way */ class DbgPermissions extends DebuggerCommand { /// \b Must have function to announce command name in debugger console public function name() { return 'perm'; } /// \b Must have function to provide help to debugger console public function description() { return 'Show current permissions in a convenient way'; } /// \b Must have function to provide help to debugger console public function syntax() { return 'perm [partial-name]'; } /// \b Must have function to show example of usage of given command public function example() { return 'perm' . "\n" . 'perm admin' . "\n" . 'perm .*_comments$'; } /// Execute command with given set of arguments. public function execute($params) { $userlib = TikiLib::lib('user'); $smarty = TikiLib::lib('smarty'); $this->set_result_type(TPL_RESULT); $this->set_result_tpl('debug/tiki-debug_permissions.tpl'); // Is regex to match against var name given? $p = explode(' ', trim($params)); $mask = count($p) > 0 ? str_replace('$', '', trim($p[0])) : ''; // Get list of all vars $tpl_vars = $smarty->getTemplateVars(); // Get descriptions for all permissions $pd = $userlib->get_permissions(); $descriptions = []; foreach ($pd['data'] as $p) { $descriptions[$p['permName']] = $p['permDesc']; } // convert to vector of names, filter permissions only $perms = []; $len = strlen($mask); foreach ($tpl_vars as $key => $val) { if ((! $len || $len && preg_match('/' . $mask . '/', $key)) && preg_match('/tiki_p_/', $key)) { $perms[] = [ 'name' => $key, 'value' => $val, 'description' => isset($descriptions[$key]) ? $descriptions[$key] : 'No description' ]; } } return $perms; } } /// Class factory to create instances of defined commands function dbg_command_factory_perm() { return new DbgPermissions(); }