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 ]]>