Zend_Controller_Router_Route_Chain
Zend_Controller_Router_Route_Chain est une route permettant le chainage
d'autres routes. Ceci permet de chainer des routes hostnames à des routes de chemin, ou de multiples
routes de chemin entre elles, par exemple. Le chainage se configure via des méthodes ou un fichier
de configuration.
Priorité des paramètres
En chainant des routes entre elles, les paramètres de la route la plus externe
(la plus proche) ont une prioprité supérieure aux paramètres des routes les plus
internes (encapsulées). Définir un contrôleur dans la route externe, puis dans la route
interne, c'est celui de la route externe qui sera sélectionné.
En réalisant le chainage via les méthodes, il existe 2 manières de procéder. La première
est de créer un objet Zend_Controller_Router_Route_Chain puis
d'appeler la méthode chain() plusieurs fois en lui passant les routes à chainer.
La deuxième méthode consiste à créer la première route, par exemple une route hostname, puis
d'appeler sa méthode chain() en passant comme paramètre la route qui devrait
être ajoutée. Ceci ne modifiera pas la route hostname, mais retournera une instance de
Zend_Controller_Router_Route_Chain possédant les 2 routes chainées:
chain($hostnameRoute)
->chain($pathRoute);
// Deuxième méthode, chainage direct
$chainedRoute = $hostnameRoute->chain($pathRoute);
]]>
Le chainage utilise le slash comme séparateur par défaut entre les routes.
Pour utiliser un séparateur différent, procédez comme suite:
chain($secondRoute, '-');
// Assemble la route: "foo-bar"
echo $chainedRoute->assemble();
]]>
Chainer des routes via Zend_Config
Pour chainer les route grâce à un fichier de configuration, il faut considérer des paramètres
additionnels. L'approche la plus simple consiste à utiliser les paramètres de la
section chains. Il s'agit simplement d'une liste de routes qui seront chainées à
la route parente. Ce n'est ni le parent, ni un des enfants qui sera ajouté au routeur, mais bien
le résultat de la chaine générale. Le nom de cette chaine dans le routeur sera constitué du nom
de la route parente séparé du nom des enfants par un tiret (-) par défaut. Voici un exemple:
www.example.com
:language
imprint
users.example.com
:username
misc
]]>
Le résultat sera 3 routes www-language-index,
www-language-imprint et
users-language-profile qui seront utilisées en fonction du nom d'hote
et de la route misc, qui elle sera utilisée pour tout nom d'hôte.
Autre manière de faire : utiliser les nom des routes directement. Cela ne peut se faire
que pour le niveau racine:
www.example.com
:language
imprint
www, language, index
www, language, imprint
]]>
On peut aussi passer un tableau à chain plutôt que les noms de route séparés par des virgules:
www
language
index
www
language
imprint
]]>
Pour spécifier le séparateur de routes avec Zend_Config
, agissez comme suit:
array(
'type' => 'Zend_Controller_Router_Route_Static',
'route' => 'foo',
'chains' => array(
'subRouteName' => array(
'type' => 'Zend_Controller_Router_Route_Static',
'route' => 'bar',
'defaults' => array(
'module' => 'module',
'controller' => 'controller',
'action' => 'action'
)
)
)
)
));
// Affecte un séparateur avant configuration
$router->setChainNameSeparator('_separator_')
// Ajoute la configuration
$router->addConfig($config);
// La nom de notre route est maintenant: chainName_separator_subRouteName
echo $this->_router->assemble(array(), 'chainName_separator_subRouteName');
// La preuve: cela affiche /foo/bar
]]>