Class RedirectRoute

Redirect route will perform an immediate redirect. Redirect routes are useful when you want to have Routing layer redirects occur in your application, for when URLs move.

Redirection is signalled by an exception that halts route matching and defines the redirect URL and status code.

Cake\Routing\Route\Route
Extended by Cake\Routing\Route\RedirectRoute

Properties summary

Inherited Properties

Method Summary

  • __construct() public
    Constructor
  • match() public
    There is no reverse routing redirection routes.
  • parse() public

    Parses a string URL into an array. Parsed URLs will result in an automatic redirection.

Method Detail

__construct()source public

__construct( string $template , array|string $defaults [] , array $options [] )

Constructor

Parameters

string $template
Template string with parameter placeholders
array|string $defaults optional []
Defaults for the route.
array $options optional []
Array of additional options for the Route

Overrides

Cake\Routing\Route\Route::__construct()

match()source public

match( array $url , array $context [] )

There is no reverse routing redirection routes.

Parameters

array $url
Array of parameters to convert to a string.
array $context optional []
Array of request context parameters.

Returns

boolean
Always false.

Overrides

Cake\Routing\Route\Route::match()

parse()source public

parse( string $url , string $method '' )

Parses a string URL into an array. Parsed URLs will result in an automatic redirection.

Parameters

string $url
The URL to parse.
string $method optional ''
The HTTP method being used.

Returns

false|null
False on failure. An exception is raised on a successful match.

Throws

Cake\Routing\Exception\RedirectException

An exception is raised on successful match. This is used to halt route matching and signal to the middleware that a redirect should happen.


Overrides

Cake\Routing\Route\Route::parse()

Methods inherited from Cake\Routing\Route\Route

__set_state()source public static

__set_state( array $fields )

Set state magic method to support var_export

This method helps for applications that want to implement router caching.

Parameters

array $fields
Key/Value of object attributes

Returns

Cake\Routing\Route\Route
A new instance of the route

_matchMethod()source protected

_matchMethod( array $url )

Check whether or not the URL's HTTP method matches.

Parameters

array $url
The array for the URL being generated.

Returns

boolean

_parseArgs()source protected

_parseArgs( string $args , string $context )

Parse passed parameters into a list of passed args.

Return true if a given named $param's $val matches a given $rule depending on $context. Currently implemented rule types are controller, action and match that can be combined with each other.

Parameters

string $args
A string with the passed params. eg. /1/foo
string $context
The current route context, which should contain controller/action keys.

Returns

array
Array of passed args.

_parseExtension()source protected

_parseExtension( string $url )

Removes the extension from $url if it contains a registered extension. If no registered extension is found, no extension is returned and the URL is returned unmodified.

Parameters

string $url
The url to parse.

Returns

array
containing url, extension

_persistParams()source protected

_persistParams( array $url , array $params )

Apply persistent parameters to a URL array. Persistent parameters are a special key used during route creation to force route parameters to persist when omitted from a URL array.

Parameters

array $url
The array to apply persistent parameters to.
array $params
An array of persistent values to replace persistent ones.

Returns

array
An array with persistent parameters applied.

_writeRoute()source protected

_writeRoute( )

Builds a route regular expression.

Uses the template, defaults and options properties to compile a regular expression that can be used to parse request strings.

_writeUrl()source protected

_writeUrl( array $params , array $pass [] , array $query [] )

Converts a matching route array into a URL string.

Composes the string URL using the template used to create the route.

Parameters

array $params
The params to convert to a string url
array $pass optional []
The additional passed arguments
array $query optional []
An array of parameters

Returns

string
Composed route string.

compile()source public

compile( )

Compiles the route's regular expression.

Modifies defaults property so all necessary keys are set and populates $this->names with the named routing elements.

Returns

array
Returns a string regular expression of the compiled route.

compiled()source public

compiled( )

Check if a Route has been compiled into a regular expression.

Returns

boolean

extensions()source public

extensions( null|string|array $extensions null )

Get/Set the supported extensions for this route.

Deprecated

3.3.9 Use getExtensions/setExtensions instead.

Parameters

null|string|array $extensions optional null
The extensions to set. Use null to get.

Returns

array|null
The extensions or null.

getExtensions()source public

getExtensions( )

Get the supported extensions for this route.

Returns

array

getName()source public

getName( )

Get the standardized plugin.controller:action name for a route.

Returns

string

setExtensions()source public

setExtensions( array $extensions )

Set the supported extensions for this route.

Parameters

array $extensions
The extensions to set.

Returns


$this

staticPath()source public

staticPath( )

Get the static path portion for this route.

Returns

string

Properties detail

$redirectsource

public array|string

The location to redirect to. Either a string or a CakePHP array URL.

$responsesource

public Cake\Network\Response

A Response object

Deprecated

3.2.0 This property is unused.
null

© 2005–2017 The Cake Software Foundation, Inc.
Licensed under the MIT License.
CakePHP is a registered trademark of Cake Software Foundation, Inc.
We are not endorsed by or affiliated with CakePHP.
https://api.cakephp.org/3.3/class-Cake.Routing.Route.RedirectRoute.html