1 | <?php (defined('BASEPATH')) OR exit('No direct script access allowed');
|
---|
2 |
|
---|
3 | /**
|
---|
4 | * Modular Extensions - HMVC
|
---|
5 | *
|
---|
6 | * Adapted from the CodeIgniter Core Classes
|
---|
7 | * @link http://codeigniter.com
|
---|
8 | *
|
---|
9 | * Description:
|
---|
10 | * This library extends the CodeIgniter CI_Loader class
|
---|
11 | * and adds features allowing use of modules and the HMVC design pattern.
|
---|
12 | *
|
---|
13 | * Install this file as application/third_party/MX/Loader.php
|
---|
14 | *
|
---|
15 | * @copyright Copyright (c) 2011 Wiredesignz
|
---|
16 | * @version 5.4
|
---|
17 | *
|
---|
18 | * Permission is hereby granted, free of charge, to any person obtaining a copy
|
---|
19 | * of this software and associated documentation files (the "Software"), to deal
|
---|
20 | * in the Software without restriction, including without limitation the rights
|
---|
21 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
---|
22 | * copies of the Software, and to permit persons to whom the Software is
|
---|
23 | * furnished to do so, subject to the following conditions:
|
---|
24 | *
|
---|
25 | * The above copyright notice and this permission notice shall be included in
|
---|
26 | * all copies or substantial portions of the Software.
|
---|
27 | *
|
---|
28 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
---|
29 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
---|
30 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
---|
31 | * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
---|
32 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
---|
33 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
---|
34 | * THE SOFTWARE.
|
---|
35 | **/
|
---|
36 | class MX_Loader extends CI_Loader
|
---|
37 | {
|
---|
38 | protected $_module;
|
---|
39 |
|
---|
40 | public $_ci_plugins = array();
|
---|
41 | public $_ci_cached_vars = array();
|
---|
42 |
|
---|
43 | /** Initialize the loader variables **/
|
---|
44 | public function initialize($controller = NULL) {
|
---|
45 |
|
---|
46 | /* set the module name */
|
---|
47 | $this->_module = CI::$APP->router->fetch_module();
|
---|
48 |
|
---|
49 | if (is_a($controller, 'MX_Controller')) {
|
---|
50 |
|
---|
51 | /* reference to the module controller */
|
---|
52 | $this->controller = $controller;
|
---|
53 |
|
---|
54 | /* references to ci loader variables */
|
---|
55 | foreach (get_class_vars('CI_Loader') as $var => $val) {
|
---|
56 | if ($var != '_ci_ob_level') {
|
---|
57 | $this->$var =& CI::$APP->load->$var;
|
---|
58 | }
|
---|
59 | }
|
---|
60 |
|
---|
61 | } else {
|
---|
62 | parent::initialize();
|
---|
63 |
|
---|
64 | /* autoload module items */
|
---|
65 | $this->_autoloader(array());
|
---|
66 | }
|
---|
67 |
|
---|
68 | /* add this module path to the loader variables */
|
---|
69 | $this->_add_module_paths($this->_module);
|
---|
70 | }
|
---|
71 |
|
---|
72 | /** Add a module path loader variables **/
|
---|
73 | public function _add_module_paths($module = '') {
|
---|
74 |
|
---|
75 | if (empty($module)) return;
|
---|
76 |
|
---|
77 | foreach (Modules::$locations as $location => $offset) {
|
---|
78 |
|
---|
79 | /* only add a module path if it exists */
|
---|
80 | if (is_dir($module_path = $location.$module.'/') && ! in_array($module_path, $this->_ci_model_paths))
|
---|
81 | {
|
---|
82 | array_unshift($this->_ci_model_paths, $module_path);
|
---|
83 | }
|
---|
84 | }
|
---|
85 | }
|
---|
86 |
|
---|
87 | /** Load a module config file **/
|
---|
88 | public function config($file = 'config', $use_sections = FALSE, $fail_gracefully = FALSE) {
|
---|
89 | return CI::$APP->config->load($file, $use_sections, $fail_gracefully, $this->_module);
|
---|
90 | }
|
---|
91 |
|
---|
92 | /** Load the database drivers **/
|
---|
93 | public function database($params = '', $return = FALSE, $active_record = NULL) {
|
---|
94 |
|
---|
95 | if (class_exists('CI_DB', FALSE) AND $return == FALSE AND $active_record == NULL AND isset(CI::$APP->db) AND is_object(CI::$APP->db))
|
---|
96 | return;
|
---|
97 |
|
---|
98 | require_once BASEPATH.'database/DB'.EXT;
|
---|
99 |
|
---|
100 | if ($return === TRUE) return DB($params, $active_record);
|
---|
101 |
|
---|
102 | CI::$APP->db = DB($params, $active_record);
|
---|
103 |
|
---|
104 | return CI::$APP->db;
|
---|
105 | }
|
---|
106 |
|
---|
107 | /** Load a module helper **/
|
---|
108 | public function helper($helper = array()) {
|
---|
109 |
|
---|
110 | if (is_array($helper)) return $this->helpers($helper);
|
---|
111 |
|
---|
112 | if (isset($this->_ci_helpers[$helper])) return;
|
---|
113 |
|
---|
114 | list($path, $_helper) = Modules::find($helper.'_helper', $this->_module, 'helpers/');
|
---|
115 |
|
---|
116 | if ($path === FALSE) return parent::helper($helper);
|
---|
117 |
|
---|
118 | Modules::load_file($_helper, $path);
|
---|
119 | $this->_ci_helpers[$_helper] = TRUE;
|
---|
120 | }
|
---|
121 |
|
---|
122 | /** Load an array of helpers **/
|
---|
123 | public function helpers($helpers = array()) {
|
---|
124 | foreach ($helpers as $_helper) $this->helper($_helper);
|
---|
125 | }
|
---|
126 |
|
---|
127 | /** Load a module language file **/
|
---|
128 | public function language($langfile = array(), $idiom = '', $return = FALSE, $add_suffix = TRUE, $alt_path = '') {
|
---|
129 | return CI::$APP->lang->load($langfile, $idiom, $return, $add_suffix, $alt_path, $this->_module);
|
---|
130 | }
|
---|
131 |
|
---|
132 | public function languages($languages) {
|
---|
133 | foreach($languages as $_language) $this->language($_language);
|
---|
134 | }
|
---|
135 |
|
---|
136 | /** Load a module library **/
|
---|
137 | public function library($library = '', $params = NULL, $object_name = NULL) {
|
---|
138 |
|
---|
139 | if (is_array($library)) return $this->libraries($library);
|
---|
140 |
|
---|
141 | $class = strtolower(basename($library));
|
---|
142 |
|
---|
143 | if (isset($this->_ci_classes[$class]) AND $_alias = $this->_ci_classes[$class])
|
---|
144 | return CI::$APP->$_alias;
|
---|
145 |
|
---|
146 | ($_alias = strtolower($object_name)) OR $_alias = $class;
|
---|
147 |
|
---|
148 | list($path, $_library) = Modules::find($library, $this->_module, 'libraries/');
|
---|
149 |
|
---|
150 | /* load library config file as params */
|
---|
151 | if ($params == NULL) {
|
---|
152 | list($path2, $file) = Modules::find($_alias, $this->_module, 'config/');
|
---|
153 | ($path2) AND $params = Modules::load_file($file, $path2, 'config');
|
---|
154 | }
|
---|
155 |
|
---|
156 | if ($path === FALSE) {
|
---|
157 |
|
---|
158 | $this->_ci_load_class($library, $params, $object_name);
|
---|
159 | $_alias = $this->_ci_classes[$class];
|
---|
160 |
|
---|
161 | } else {
|
---|
162 |
|
---|
163 | Modules::load_file($_library, $path);
|
---|
164 |
|
---|
165 | $library = ucfirst($_library);
|
---|
166 | CI::$APP->$_alias = new $library($params);
|
---|
167 |
|
---|
168 | $this->_ci_classes[$class] = $_alias;
|
---|
169 | }
|
---|
170 |
|
---|
171 | return CI::$APP->$_alias;
|
---|
172 | }
|
---|
173 |
|
---|
174 | /** Load an array of libraries **/
|
---|
175 | public function libraries($libraries) {
|
---|
176 | foreach ($libraries as $_library) $this->library($_library);
|
---|
177 | }
|
---|
178 |
|
---|
179 | /** Load a module model **/
|
---|
180 | public function model($model, $object_name = NULL, $connect = FALSE) {
|
---|
181 |
|
---|
182 | if (is_array($model)) return $this->models($model);
|
---|
183 |
|
---|
184 | ($_alias = $object_name) OR $_alias = basename($model);
|
---|
185 |
|
---|
186 | if (in_array($_alias, $this->_ci_models, TRUE))
|
---|
187 | return CI::$APP->$_alias;
|
---|
188 |
|
---|
189 | /* check module */
|
---|
190 | list($path, $_model) = Modules::find(strtolower($model), $this->_module, 'models/');
|
---|
191 |
|
---|
192 | if ($path == FALSE) {
|
---|
193 |
|
---|
194 | /* check application & packages */
|
---|
195 | parent::model($model, $object_name, $connect);
|
---|
196 |
|
---|
197 | } else {
|
---|
198 |
|
---|
199 | class_exists('CI_Model', FALSE) OR load_class('Model', 'core');
|
---|
200 |
|
---|
201 | if ($connect !== FALSE AND ! class_exists('CI_DB', FALSE)) {
|
---|
202 | if ($connect === TRUE) $connect = '';
|
---|
203 | $this->database($connect, FALSE, TRUE);
|
---|
204 | }
|
---|
205 |
|
---|
206 | Modules::load_file($_model, $path);
|
---|
207 |
|
---|
208 | $model = ucfirst($_model);
|
---|
209 | CI::$APP->$_alias = new $model();
|
---|
210 |
|
---|
211 | $this->_ci_models[] = $_alias;
|
---|
212 | }
|
---|
213 |
|
---|
214 | return CI::$APP->$_alias;
|
---|
215 | }
|
---|
216 |
|
---|
217 | /** Load an array of models **/
|
---|
218 | public function models($models) {
|
---|
219 | foreach ($models as $_model) $this->model($_model);
|
---|
220 | }
|
---|
221 |
|
---|
222 | /** Load a module controller **/
|
---|
223 | public function module($module, $params = NULL) {
|
---|
224 |
|
---|
225 | if (is_array($module)) return $this->modules($module);
|
---|
226 |
|
---|
227 | $_alias = strtolower(basename($module));
|
---|
228 | CI::$APP->$_alias = Modules::load(array($module => $params));
|
---|
229 | return CI::$APP->$_alias;
|
---|
230 | }
|
---|
231 |
|
---|
232 | /** Load an array of controllers **/
|
---|
233 | public function modules($modules) {
|
---|
234 | foreach ($modules as $_module) $this->module($_module);
|
---|
235 | }
|
---|
236 |
|
---|
237 | /** Load a module plugin **/
|
---|
238 | public function plugin($plugin) {
|
---|
239 |
|
---|
240 | if (is_array($plugin)) return $this->plugins($plugin);
|
---|
241 |
|
---|
242 | if (isset($this->_ci_plugins[$plugin]))
|
---|
243 | return;
|
---|
244 |
|
---|
245 | list($path, $_plugin) = Modules::find($plugin.'_pi', $this->_module, 'plugins/');
|
---|
246 |
|
---|
247 | if ($path === FALSE AND ! is_file($_plugin = APPPATH.'plugins/'.$_plugin.EXT)) {
|
---|
248 | show_error("Unable to locate the plugin file: {$_plugin}");
|
---|
249 | }
|
---|
250 |
|
---|
251 | Modules::load_file($_plugin, $path);
|
---|
252 | $this->_ci_plugins[$plugin] = TRUE;
|
---|
253 | }
|
---|
254 |
|
---|
255 | /** Load an array of plugins **/
|
---|
256 | public function plugins($plugins) {
|
---|
257 | foreach ($plugins as $_plugin) $this->plugin($_plugin);
|
---|
258 | }
|
---|
259 |
|
---|
260 | /** Load a module view **/
|
---|
261 | public function view($view, $vars = array(), $return = FALSE) {
|
---|
262 | list($path, $_view) = Modules::find($view, $this->_module, 'views/');
|
---|
263 |
|
---|
264 | if ($path != FALSE) {
|
---|
265 | $this->_ci_view_paths = array($path => TRUE) + $this->_ci_view_paths;
|
---|
266 | $view = $_view;
|
---|
267 | }
|
---|
268 |
|
---|
269 | return $this->_ci_load(array('_ci_view' => $view, '_ci_vars' => $this->_ci_object_to_array($vars), '_ci_return' => $return));
|
---|
270 | }
|
---|
271 |
|
---|
272 | public function _ci_is_instance() {}
|
---|
273 |
|
---|
274 | protected function &_ci_get_component($component) {
|
---|
275 | return CI::$APP->$component;
|
---|
276 | }
|
---|
277 |
|
---|
278 | public function __get($class) {
|
---|
279 | return (isset($this->controller)) ? $this->controller->$class : CI::$APP->$class;
|
---|
280 | }
|
---|
281 |
|
---|
282 | public function _ci_load($_ci_data) {
|
---|
283 |
|
---|
284 | extract($_ci_data);
|
---|
285 |
|
---|
286 | if (isset($_ci_view)) {
|
---|
287 |
|
---|
288 | $_ci_path = '';
|
---|
289 |
|
---|
290 | /* add file extension if not provided */
|
---|
291 | $_ci_file = (pathinfo($_ci_view, PATHINFO_EXTENSION)) ? $_ci_view : $_ci_view.EXT;
|
---|
292 |
|
---|
293 | foreach ($this->_ci_view_paths as $path => $cascade) {
|
---|
294 | if (file_exists($view = $path.$_ci_file)) {
|
---|
295 | $_ci_path = $view;
|
---|
296 | break;
|
---|
297 | }
|
---|
298 |
|
---|
299 | if ( ! $cascade) break;
|
---|
300 | }
|
---|
301 |
|
---|
302 | } elseif (isset($_ci_path)) {
|
---|
303 |
|
---|
304 | $_ci_file = basename($_ci_path);
|
---|
305 | if( ! file_exists($_ci_path)) $_ci_path = '';
|
---|
306 | }
|
---|
307 |
|
---|
308 | if (empty($_ci_path))
|
---|
309 | show_error('Unable to load the requested file: '.$_ci_file);
|
---|
310 |
|
---|
311 | if (isset($_ci_vars))
|
---|
312 | $this->_ci_cached_vars = array_merge($this->_ci_cached_vars, (array) $_ci_vars);
|
---|
313 |
|
---|
314 | extract($this->_ci_cached_vars);
|
---|
315 |
|
---|
316 | ob_start();
|
---|
317 |
|
---|
318 | if ((bool) @ini_get('short_open_tag') === FALSE AND CI::$APP->config->item('rewrite_short_tags') == TRUE) {
|
---|
319 | echo eval('?>'.preg_replace("/;*\s*\?>/", "; ?>", str_replace('<?=', '<?php echo ', file_get_contents($_ci_path))));
|
---|
320 | } else {
|
---|
321 | include($_ci_path);
|
---|
322 | }
|
---|
323 |
|
---|
324 | log_message('debug', 'File loaded: '.$_ci_path);
|
---|
325 |
|
---|
326 | if ($_ci_return == TRUE) return ob_get_clean();
|
---|
327 |
|
---|
328 | if (ob_get_level() > $this->_ci_ob_level + 1) {
|
---|
329 | ob_end_flush();
|
---|
330 | } else {
|
---|
331 | CI::$APP->output->append_output(ob_get_clean());
|
---|
332 | }
|
---|
333 | }
|
---|
334 |
|
---|
335 | /** Autoload module items **/
|
---|
336 | public function _autoloader($autoload) {
|
---|
337 |
|
---|
338 | $path = FALSE;
|
---|
339 |
|
---|
340 | if ($this->_module) {
|
---|
341 |
|
---|
342 | list($path, $file) = Modules::find('constants', $this->_module, 'config/');
|
---|
343 |
|
---|
344 | /* module constants file */
|
---|
345 | if ($path != FALSE) {
|
---|
346 | include_once $path.$file.EXT;
|
---|
347 | }
|
---|
348 |
|
---|
349 | list($path, $file) = Modules::find('autoload', $this->_module, 'config/');
|
---|
350 |
|
---|
351 | /* module autoload file */
|
---|
352 | if ($path != FALSE) {
|
---|
353 | $autoload = array_merge(Modules::load_file($file, $path, 'autoload'), $autoload);
|
---|
354 | }
|
---|
355 | }
|
---|
356 |
|
---|
357 | /* nothing to do */
|
---|
358 | if (count($autoload) == 0) return;
|
---|
359 |
|
---|
360 | /* autoload package paths */
|
---|
361 | if (isset($autoload['packages'])) {
|
---|
362 | foreach ($autoload['packages'] as $package_path) {
|
---|
363 | $this->add_package_path($package_path);
|
---|
364 | }
|
---|
365 | }
|
---|
366 |
|
---|
367 | /* autoload config */
|
---|
368 | if (isset($autoload['config'])) {
|
---|
369 | foreach ($autoload['config'] as $config) {
|
---|
370 | $this->config($config);
|
---|
371 | }
|
---|
372 | }
|
---|
373 |
|
---|
374 | /* autoload helpers, plugins, languages */
|
---|
375 | foreach (array('helper', 'plugin', 'language') as $type) {
|
---|
376 | if (isset($autoload[$type])){
|
---|
377 | foreach ($autoload[$type] as $item) {
|
---|
378 | $this->$type($item);
|
---|
379 | }
|
---|
380 | }
|
---|
381 | }
|
---|
382 |
|
---|
383 | /* autoload database & libraries */
|
---|
384 | if (isset($autoload['libraries'])) {
|
---|
385 | if (in_array('database', $autoload['libraries'])) {
|
---|
386 | /* autoload database */
|
---|
387 | if ( ! $db = CI::$APP->config->item('database')) {
|
---|
388 | $db['params'] = 'default';
|
---|
389 | $db['active_record'] = TRUE;
|
---|
390 | }
|
---|
391 | $this->database($db['params'], FALSE, $db['active_record']);
|
---|
392 | $autoload['libraries'] = array_diff($autoload['libraries'], array('database'));
|
---|
393 | }
|
---|
394 |
|
---|
395 | /* autoload libraries */
|
---|
396 | foreach ($autoload['libraries'] as $library) {
|
---|
397 | $this->library($library);
|
---|
398 | }
|
---|
399 | }
|
---|
400 |
|
---|
401 | /* autoload models */
|
---|
402 | if (isset($autoload['model'])) {
|
---|
403 | foreach ($autoload['model'] as $model => $alias) {
|
---|
404 | (is_numeric($model)) ? $this->model($alias) : $this->model($model, $alias);
|
---|
405 | }
|
---|
406 | }
|
---|
407 |
|
---|
408 | /* autoload module controllers */
|
---|
409 | if (isset($autoload['modules'])) {
|
---|
410 | foreach ($autoload['modules'] as $controller) {
|
---|
411 | ($controller != $this->_module) AND $this->module($controller);
|
---|
412 | }
|
---|
413 | }
|
---|
414 | }
|
---|
415 | }
|
---|
416 |
|
---|
417 | /** load the CI class for Modular Separation **/
|
---|
418 | (class_exists('CI', FALSE)) OR require dirname(__FILE__).'/Ci.php'; |
---|