2
0

Zend_Controller-Router-Route-Chain.xml 8.0 KB

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