|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 | <?php // // Open Web Analytics - An Open Source Web Analytics Framework // // Copyright 2006 Peter Adams. All rights reserved. // // Licensed under GPL v2.0 http://www.gnu.org/copyleft/gpl.html // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // // $Id$ // require_once(OWA_BASE_CLASSES_DIR.'owa_adminController.php'); require_once(OWA_BASE_CLASSES_DIR.'owa_view.php'); /** * Options Modules Roster Controller * * @author Peter Adams <peter@openwebanalytics.com> * @copyright Copyright © 2006 Peter Adams <peter@openwebanalytics.com> * @license http://www.gnu.org/copyleft/gpl.html GPL v2.0 * @category owa * @package owa * @version $Revision$ * @since owa 1.0.0 */ class owa_optionsModulesController extends owa_adminController { function __construct($params) { $this->setRequiredCapability('edit_modules'); return parent::__construct($params); } function action() { $path = OWA_BASE_CLASSES_DIR.'modules'.DIRECTORY_SEPARATOR; $dirs = array(); if ($handle = opendir($path)): while (($file = readdir($handle)) !== false) { // test for '.' in dir name if (strpos($file, '.') === false): // test for whether file is a dir if (is_dir($path.$file)): $mod = owa_coreAPI::moduleClassFactory($file); $dirs[$file]['name'] = $mod->name; $dirs[$file]['display_name'] = $mod->display_name; $dirs[$file]['author'] = $mod->author; $dirs[$file]['group'] = $mod->group; $dirs[$file]['version'] = $mod->version; $dirs[$file]['description'] = $mod->description; $dirs[$file]['config_required'] = $mod->config_required; $dirs[$file]['current_schema_version'] = $mod->getSchemaVersion(); $dirs[$file]['required_schema_version'] = $mod->getRequiredSchemaVersion(); $dirs[$file]['schema_uptodate'] = $mod->isSchemaCurrent(); //$dirs['stats'] = lstat($path.$file); endif; endif; } endif; closedir($handle); ksort($dirs); // remove base module so it can't be deactivated // unset($dirs['base']); $active_modules = owa_coreAPI::getActiveModules(); foreach ($active_modules as $module) { if (!empty($dirs[$module])): $dirs[$module]['status'] = 'active'; endif; } // add data to container $this->setView('base.options'); $this->setSubview('base.optionsModules'); $this->set('modules', $dirs); return; } } /** * Options Modules View * * @author Peter Adams <peter@openwebanalytics.com> * @copyright Copyright © 2006 Peter Adams <peter@openwebanalytics.com> * @license http://www.gnu.org/copyleft/gpl.html GPL v2.0 * @category owa * @package owa * @version $Revision$ * @since owa 1.0.0 */ class owa_optionsModulesView extends owa_view { function __construct($params) { //set priviledge level $this->_setPriviledgeLevel('admin'); //set page type $this->_setPageType('Administration Page'); return parent::__construct(); } function render($data) { //$this->c->get('base', 'modules')); // load template $this->body->set_template('options_modules.tpl'); // fetch admin links from all modules $this->body->set('headline', 'Modules Administration'); // Assign module data $this->body->set('modules', $this->get('modules')); } } ?> |