josegonzalez / cakephp-page-route
Automagically route /:page style routes without any fuss in CakePHP
Installs: 17
Dependents: 0
Suggesters: 0
Security: 0
Stars: 19
Watchers: 5
Forks: 2
Open Issues: 0
Type:cakephp-plugin
Requires
This package is auto-updated.
Last update: 2024-09-29 04:48:38 UTC
README
PageRoute Plugin
Forget about cluttering your routes.php
with zillions of /page
-style routes.
Background
Someone in IRC was migrating tons of static pages into a fresh CakePHP install. In the webroot. I told him to move them into app/View/Pages
and use routes to properly route everything. I also mentioned that rather than routing every static file one by one, it might be possible using a custom CakeRoute
class, but didn't elaborate.
So a few minutes of hacking later, and here I am with this lovely PageRoute
.
Requirements
- PHP 5.2+
- CakePHP 2.x
Installation
[Using Composer]
Add the plugin to your project's composer.json
- something like this:
{
"require": {
"josegonzalez/cakephp-page-route": "1.0.0"
}
}
Because this plugin has the type cakephp-plugin
set in it's own composer.json
, composer knows to install it inside your /Plugins
directory, rather than in the usual vendors file. It is recommended that you add /Plugins/PageRoute
to your .gitignore file. (Why? read this.)
[Manual]
- Download this: https://github.com/josegonzalez/cakephp-page-route/zipball/master
- Unzip that download.
- Copy the resulting folder to
app/Plugin
- Rename the folder you just copied to
PageRoute
[GIT Submodule]
In your app directory type:
git submodule add git://github.com/josegonzalez/cakephp-page-route.git Plugin/PageRoute
git submodule init
git submodule update
[GIT Clone]
In your plugin directory type
git clone git://github.com/josegonzalez/cakephp-page-route.git PageRoute
Enable plugin
In 2.0 you need to enable the plugin your app/Config/bootstrap.php
file:
CakePlugin::load('PageRoute');
If you are already using CakePlugin::loadAll();
, then this is not necessary.
Usage
Way near the bottom of your app/Config/routes.php
file, add the following:
<?php App::uses('PageRoute', 'PageRoute.Routing/Route'); Router::connect('/:page', array('controller' => 'pages', 'action' => 'display'), array('routeClass' => 'PageRoute') );
And now you can remove all shortcuts to your /pages/display/page-name
urls. Whenever you create a new .ctp
file in app/View/Pages
, this route will automatically detect it using a file_exists()
call. Because of this, it is recommended to use this as one of the last, if not the last, route in your application, in order to minimize file-reads.
It is also possible to customize the controller/action used for this. For example, we might want to use the StaticPagesController::index()
instead of PagesController::display()
. In that case, our routes.php
would look like the following:
<?php App::uses('PageRoute', 'PageRoute.Routing/Route'); Router::connect('/:page', array('controller' => 'static_pages', 'action' => 'index'), array('routeClass' => 'PageRoute', 'controller' => 'static_pages', 'action' => 'index') );
In this way, we can easily rename the PagesController
to something less useful, and reuse the PagesController
for something else - such as dynamic content from the database.
Reverse routing will all work the same as it does without this route class. array('controller' => 'pages', 'action' => 'display', 'about')
will be automatically converted to array('controller' => 'pages', 'action' => 'display', 'page' =. 'about')
for backwards compatibility Please note that by default, the regex [\/\w_-]+
is used to check the page validity, so you may need to update that regex in the Route options as follows:
App::uses('PageRoute', 'PageRoute.Routing/Route'); Router::connect('/:page', array('controller' => 'static_pages', 'action' => 'index'), array('routeClass' => 'PageRoute', 'page' => '[a-zA-Z]+') );
Note that the .
character has been disallowed in the default regex to remove the possibility of traversing the directory tree for security reasons.
Todo
- Unit Tests
- Allow usage of the
.
character in routes - Add caching to file_exists calls