-
Notifications
You must be signed in to change notification settings - Fork 0
Matchbox
Current version: File:Matchbox-RC2.zip Forum Thread: [url]http://codeigniter.com/forums/viewthread/128084/[/url] Last update: 2009-09-18
Matchbox is a set of extended libraries that lets you organize your application in small components (modules). These modules have several advantages, the main one being portability. Modules are stored in their own folders and so they can be reused in other applications or shared between users by copying just that one folder.
If you can run CodeIgniter, you've already met the server requirements, thus all you have to do is download and unzip the latest version of Matchbox right into your application directory. File:Matchbox-RC2.zip
To test your installation, open up your browser and test the uri http://yoursite.com/pathto/index.php/matchbox/.
If you see the Matchbox dashboard, you've successfully installed Matchbox!
If it's not working see Troubleshooting further down this page, or if that doesn't answer your questions, ask them in the forum thread.
Installing Matchbox won't effect your current application, though. Any controllers in the APPPATH/controllers/ will work like they used to. To start modulizing your application you have to create a module.
To make a new module, you create a new folder in the APPPATH/modules/ directory. For instance, creating the directory APPPATH/modules/my_new_module/ results in a new module named 'my_new_module'.
Within this folder you place additional folders for each type of resource you need in the module. Often you'll want controllers in your module, in which case you make a 'controllers' folder in your module directory. You can also add folders for config files, helpers, languages, libraries, models, plugins and views. Your module folder should like a lot like your application directory.
So you've got a module directory with a controllers/ folder, and now you want to make a controller to place there. Luckily, module controllers are no different from regular controllers, so if you want to test Matchbox right away, you can go ahead and copy one of your exsisting controllers to your module (or just create a new one).
To access your controller, you go to http://example.com/index.php/MODULE-NAME/CONTROLLER-NAME/. Basically the only difference from accessing a regular controller, is that you have to add the module name before the controller name in the uri. If you only type in http://example.com/index.php/MODULE-NAME/ and not the controller name, Matchbox will try to load the controller with the same name as the module (unless strict mode is enabled, which is explained futher down the page). This default controller can be customized, though, which is explained a litle further down the page.
Where things start to get interesting, is when you need to load resources or helpers from your controllers. If the resource is located in the same module or in your application directory, they can be loaded as usual (unless strict mode is enabled, which is explained futher down the page).
However, if you need to load resource from another module than the one the controller resides in you'll have to tell Matchbox what module to look inside. You do this by either adding the module name as the last argument when using regular load calls.
$this->load->model('blog_model', '', FALSE, 'my_other_module');
Or alternatively, you can prefix the load call with 'module_', in which case the module name is the first argument.
$this->load->module_model('my_other_module', 'blog_model');
You can also make custom routes.php and autoload.php configuration files for your modules. Simply copy a regular CodeIgniter routes.php or autoload.php into your modules config directory and edit them to your liking.
The default_controller you set in the module routes.php file will be used instead of the module name when typing only the module name as the uri. So if you go to http://example.com/index.php/MODULE-NAME/ it will attempt to load said default controller.
You can of course also add custom routes like in the regular routes.php.
You can configure your Matchbox installation by editing the application/config/matchbox.php file. The file contains three configurable items; the 'strict' variable, 'paths' array and 'callers' array. All three are explained below.
By default, modules are located only in APPPATH/modules/, however this can be configured using the 'paths' config item in the matchbox configuration file. So if you want modules in both your application and system folders change the config item to the following.
$config['paths'] = array(APPPATH.'modules', BASEPATH.'modules');
Matchbox is able to determine where a certain load call originates from using backtraces. What this means, is that even your request starts in a regular controller, and that controller loads a library in a module and that library attempts to load a model, Matchbox will now that the calling library is located in a certain module and attempt to find the model accordingly.
However, if you have, say, a custom view library that you call instead of the regular loading of views, and that library is located in your application folder then if a module controller calls said library to load a view in the same module, then Matchbox will think that the view is located in your application directory, because the final view request comes from the custom view library located in the application folder.
To remedy this, you can add your custom view library the the caller configuration array in the matchbox configuration file.
$config['callers'] = array(APPPATH.'libraries/Custom_view_lib.php');
In the Matchbox configuration file is a strict config item than can be either TRUE or FALSE.
By default strict mode is disabled. This means that Matchbox will do several additional checks when performing searches for controllers and other resources. For instance, when the uri only contains a module name, Matchbox will attempt to find a controller with the same name as the module, but not with strict mode enabled. More importantly, with strict mode enabled, $this->load->something calls will only search for resources in the current module (and system directory) but not in the application directory. So if a module controller needs to load a helper from the application directory you must specifically do it like so:
$this->load->module_helper(APPPATH, 'some_helper')
The simple reason why you'd want to have strict mode enabled is that it speeds up your application. So you might wanna have strict mode enabled during development, and then go through your code and enable it for production.
The issue has been fixed in the latest release. Download the newest version of Matchbox.
If you use and enjoy Matchbox, please consider making a donation.
Many thanks for your continued support.
Zacharias.