/versatile_router

A front end URL routing extension for Symphony CMS.

Primary LanguagePHPMIT LicenseMIT

Versatile Router

A frontend URL router for Symphony CMS.

System Requirements

PHP version >= 5.3.

Preference Settings

Versatile Router has two settings on Symphony's System->Preferences page.

Disable standard routing

By default, rerouting/redirection is performed only when the source route does not match any page. This can be changed by disabling Symphony's standard routing, in which case you will have to define routes for all of the pages on your website.

Routes file path

Routes are defined in a file in the Workspace directory which by default is routes.php. The path (relative to workspace) may be changed.

Routes

Routes are defined in a PHP file. See Preference Settings for more details.

Define a route:

route(<source path>, <destination path>, <optional conditions>);

Define a route which responds to GET requests only:

get(<source path>, <destination path>, <optional conditions>);

Define a route which responds to POST requests only:

post(<source path>, <destination path>, <optional conditions>);

Define a redirection route. The destination needs to be a full URL:

redirect('<source path>', '<destination URL>', '<optional conditions>', '<optional status code>');

Parameters

Paths may contain parameter names, where the name is prefixed by a colon. In the destination route, the name must be enclosed in braces.

Example route with parameters:

route('/article/:title/', '/article-main/{:title}/');

Conditions

The contents of the PHP arrays $_SERVER and $_REQUEST can be tested with conditions. Parameters can be filtered using when_match.

The conditions available are:

when_set(<variable>) returns true if variable exists;

when_not_set(<variable>) returns true if variable does not exist;

when_is(<variable>) returns true if variable exists and is non-null;

when_is_not(<variable>) returns true if variable is null or non-existent;

when_equal(<variable>, <value>) returns true if variable holds specified value;

when_not_equal(<variable>, <value>) returns true if variable does not hold specified value;

when_match(<variable>, <regular expression>) returns true if variable matches PCRE regex pattern.

A single condition or an array of conditions may be used.

Wildcards

An asterisk in the source path will match any character except for a period.

Route Groups

A group of routes with common conditions can be given.

group(<conditions>, function(){<set of routes>});

Routing Examples

Redirect from HTTP to HTTPS connection:

redirect('/buy-something/, 'https://{HTTP_HOST}/buy-something/', when_not('HTTPS'));

Group for AJAX requests. The values 'article-page' and 'comments-page' are from the GET query string:

group(
	when_match('CONTENT_TYPE', '/^application\/x-www-form-urlencoded/'),
	function(){
		get('/article/:title/', '/article-ajax-page/{:title}/', when_is('article-page')); 
		get('/article/:title/', '/article-ajax-comments/{:title}/', when_is('comments-page')); 
		post('/article/:title/', '/ajax-comments/{:title}/');
	}
);