Zend_Controller-Router-Route-Chain.xml 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect3 id="zend.controller.router.routes.chain">
  4. <title>Zend_Controller_Router_Route_Chain</title>
  5. <para>
  6. <classname>Zend_Controller_Router_Route_Chain</classname> est une route permettant le chainage
  7. d'autres routes. Ceci permet de chainer des routes hostnames à des routes de chemin, ou de multiples
  8. routes de chemin entre elles, par exemple. Le chainage se configure via des méthodes ou un fichier
  9. de configuration.
  10. </para>
  11. <note>
  12. <title>Priorité des paramètres</title>
  13. <para>
  14. En chainant des routes entre elles, les paramètres de la route la plus externe
  15. (la plus proche) ont une prioprité supérieure aux paramètres des routes les plus
  16. internes (encapsulées). Définir un contrôleur dans la route externe, puis dans la route
  17. interne, c'est celui de la route externe qui sera sélectionné.
  18. </para>
  19. </note>
  20. <para>
  21. En réalisant le chainage via les méthodes, il existe 2 manières de procéder. La première
  22. est de créer un objet <classname>Zend_Controller_Router_Route_Chain</classname> puis
  23. d'appeler la méthode <code>chain()</code> plusieurs fois en lui passant les routes à chainer.
  24. La deuxième méthode consiste à créer la première route, par exemple une route hostname, puis
  25. d'appeler sa méthode <code>chain()</code> en passant comme paramètre la route qui devrait
  26. être ajoutée. Ceci ne modifiera pas la route hostname, mais retournera une instance de
  27. <classname>Zend_Controller_Router_Route_Chain</classname> possédant les 2 routes chainées:
  28. </para>
  29. <programlisting language="php"><![CDATA[
  30. // Créer deux routes
  31. $hostnameRoute = new Zend_Controller_Router_Route_Hostname(...);
  32. $pathRoute = new Zend_Controller_Router_Route(...);
  33. // Première méthode, utiliser l'objet de chainage
  34. $chainedRoute = new Zend_Controller_Router_Route_Chain();
  35. $chainedRoute->chain($hostnameRoute)
  36. ->chain($pathRoute);
  37. // Deuxième méthode, chainage direct
  38. $chainedRoute = $hostnameRoute->chain($pathRoute);
  39. ]]></programlisting>
  40. <para>
  41. Le chainage utilise le slash comme séparateur par défaut entre les routes.
  42. Pour utiliser un séparateur différent, procédez comme suite:
  43. </para>
  44. <programlisting language="php"><![CDATA[
  45. // Créer deux routes
  46. $firstRoute = new Zend_Controller_Router_Route('foo');
  47. $secondRoute = new Zend_Controller_Router_Route('bar');
  48. // Chainer les routes avec un séparateur particulier
  49. $chainedRoute = $firstRoute->chain($secondRoute, '-');
  50. // Assemble la route: "foo-bar"
  51. echo $chainedRoute->assemble();
  52. ]]></programlisting>
  53. <sect4 id="zend.controller.router.routes.chain.config">
  54. <title>Chainer des routes via Zend_Config</title>
  55. <para>
  56. Pour chainer les route grâce à un fichier de configuration, il faut considérer des paramètres
  57. additionnels. L'approche la plus simple consiste à utiliser les paramètres de la
  58. section <code>chains</code>. Il s'agit simplement d'une liste de routes qui seront chainées à
  59. la route parente. Ce n'est ni le parent, ni un des enfants qui sera ajouté au routeur, mais bien
  60. le résultat de la chaine générale. Le nom de cette chaine dans le routeur sera constitué du nom
  61. de la route parente séparé du nom des enfants par un tiret (-) par défaut. Voici un exemple:
  62. </para>
  63. <programlisting language="xml"><![CDATA[
  64. <routes>
  65. <www type="Zend_Controller_Router_Route_Hostname">
  66. <route>www.example.com</route>
  67. <chains>
  68. <language type="Zend_Controller_Router_Route">
  69. <route>:language</route>
  70. <reqs language="[a-z]{2}">
  71. <chains>
  72. <index type="Zend_Controller_Router_Route_Static">
  73. <route></route>
  74. <defaults module="default" controller="index" action="index" />
  75. </index>
  76. <imprint type="Zend_Controller_Router_Route_Static">
  77. <route>imprint</route>
  78. <defaults module="default" controller="index" action="index" />
  79. </imprint>
  80. </chains>
  81. </language>
  82. </chains>
  83. </www>
  84. <users type="Zend_Controller_Router_Route_Hostname">
  85. <route>users.example.com</route>
  86. <chains>
  87. <profile type="Zend_Controller_Router_Route">
  88. <route>:username</route>
  89. <defaults module="users" controller="profile" action="index" />
  90. </profile>
  91. </chains>
  92. </users>
  93. <misc type="Zend_Controller_Router_Route_Static">
  94. <route>misc</route>
  95. </misc>
  96. </routes>
  97. ]]></programlisting>
  98. <para>
  99. Le résultat sera 3 routes <code>www-language-index</code>,
  100. <code>www-language-imprint</code> et
  101. <code>users-language-profile</code> qui seront utilisées en fonction du nom d'hote
  102. et de la route <code>misc</code>, qui elle sera utilisée pour tout nom d'hôte.
  103. </para>
  104. <para>
  105. Autre manière de faire : utiliser les nom des routes directement. Cela ne peut se faire
  106. que pour le niveau racine:
  107. </para>
  108. <programlisting language="xml"><![CDATA[
  109. <routes>
  110. <www type="Zend_Controller_Router_Route_Chain">
  111. <route>www.example.com</route>
  112. </www>
  113. <language type="Zend_Controller_Router_Route">
  114. <route>:language</route>
  115. <reqs language="[a-z]{2}">
  116. </language>
  117. <index type="Zend_Controller_Router_Route_Static">
  118. <route></route>
  119. <defaults module="default" controller="index" action="index" />
  120. </index>
  121. <imprint type="Zend_Controller_Router_Route_Static">
  122. <route>imprint</route>
  123. <defaults module="default" controller="index" action="index" />
  124. </imprint>
  125. <www-index type="Zend_Controller_Router_Route_Chain">
  126. <chain>www, language, index</chain>
  127. </www-index>
  128. <www-imprint type="Zend_Controller_Router_Route_Chain">
  129. <chain>www, language, imprint</chain>
  130. </www-imprint>
  131. </routes>
  132. ]]></programlisting>
  133. <para>
  134. On peut aussi passer un tableau à <code>chain</code> plutôt que les noms de route séparés par des virgules:
  135. </para>
  136. <programlisting language="xml"><![CDATA[
  137. <routes>
  138. <www-index type="Zend_Controller_Router_Route_Chain">
  139. <chain>www</chain>
  140. <chain>language</chain>
  141. <chain>index</chain>
  142. </www-index>
  143. <www-imprint type="Zend_Controller_Router_Route_Chain">
  144. <chain>www</chain>
  145. <chain>language</chain>
  146. <chain>imprint</chain>
  147. </www-imprint>
  148. </routes>
  149. ]]></programlisting>
  150. <para>
  151. Pour spécifier le séparateur de routes avec <classname>Zend_Config</classname>
  152. , agissez comme suit:
  153. </para>
  154. <programlisting language="php"><![CDATA[
  155. $config = new Zend_Config(array(
  156. 'chainName' => array(
  157. 'type' => 'Zend_Controller_Router_Route_Static',
  158. 'route' => 'foo',
  159. 'chains' => array(
  160. 'subRouteName' => array(
  161. 'type' => 'Zend_Controller_Router_Route_Static',
  162. 'route' => 'bar',
  163. 'defaults' => array(
  164. 'module' => 'module',
  165. 'controller' => 'controller',
  166. 'action' => 'action'
  167. )
  168. )
  169. )
  170. )
  171. ));
  172. // Affecte un séparateur avant configuration
  173. $router->setChainNameSeparator('_separator_')
  174. // Ajoute la configuration
  175. $outer->addConfig($config);
  176. // La nom de notre route est maintenant: chainName_separator_subRouteName
  177. echo $this->_router->assemble(array(), 'chainName_separator_subRouteName');
  178. // La preuve: cela affiche /foo/bar
  179. ]]></programlisting>
  180. </sect4>
  181. </sect3>
  182. <!--
  183. vim:se ts=4 sw=4 et:
  184. -->