Zend_Tool_Framework-Architecture.xml 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.tool.framework.architecture">
  5. <title>アーキテクチャ</title>
  6. <sect2 id="zend.tool.framework.architecture.registry">
  7. <title>レジストリ</title>
  8. <para>
  9. <property>include_path</property>のどこからでもプロバイダとマニフェストが由来するかもしれないので、
  10. ツール・チェーンのいろいろな部分へのアクセスを単純化するためにレジストリが提供されます。
  11. このレジストリはレジストリを認識するコンポーネントに注入されます。
  12. そして、それから必要に応じてそれは彼らから依存性を引き出すかもしれません。
  13. レジストリで登録される依存性の多くは、下位-構成要素に特有のリポジトリです。
  14. </para>
  15. <para>
  16. レジストリのためのインターフェースは、以下の定義から成ります。:
  17. </para>
  18. <programlisting language="php"><![CDATA[
  19. interface Zend_Tool_Framework_Registry_Interface
  20. {
  21. public function setClient(Zend_Tool_Framework_Client_Abstract $client);
  22. public function getClient();
  23. public function setLoader(Zend_Tool_Framework_Loader_Abstract $loader);
  24. public function getLoader();
  25. public function setActionRepository(
  26. Zend_Tool_Framework_Action_Repository $actionRepository
  27. );
  28. public function getActionRepository();
  29. public function setProviderRepository(
  30. Zend_Tool_Framework_Provider_Repository $providerRepository
  31. );
  32. public function getProviderRepository();
  33. public function setManifestRepository(
  34. Zend_Tool_Framework_Manifest_Repository $manifestRepository
  35. );
  36. public function getManifestRepository();
  37. public function setRequest(Zend_Tool_Framework_Client_Request $request);
  38. public function getRequest();
  39. public function setResponse(Zend_Tool_Framework_Client_Response $response);
  40. public function getResponse();
  41. }
  42. ]]></programlisting>
  43. <para>
  44. レジストリが管理するいろいろなオブジェクトは、それらに該当する部分で論じられます。
  45. </para>
  46. <para>
  47. レジストリを認識しなければならないクラスは、
  48. <classname>Zend_Tool_Framework_Registry_EnabledInterface</classname>を実行しなければなりません。
  49. このインターフェースは、単に対象クラスだけでレジストリの初期化を可能にします。
  50. </para>
  51. <programlisting language="php"><![CDATA[
  52. interface Zend_Tool_Framework_Registry_EnabledInterface
  53. {
  54. public function setRegistry(
  55. Zend_Tool_Framework_Registry_Interface $registry
  56. );
  57. }
  58. ]]></programlisting>
  59. </sect2>
  60. <sect2 id="zend.tool.framework.architecture.providers">
  61. <title>プロバイダ</title>
  62. <para>
  63. <classname>Zend_Tool_Framework_Provider</classname>は、
  64. フレームワークの機能または「能力」面を表現します。
  65. 基本的に、<classname>Zend_Tool_Framework_Provider</classname>は
  66. 「プロバイダ」をもたらすために必要なインターフェース、
  67. または<classname>Zend_Tool_Framework</classname>ツール・チェーン内で呼ぶことができて、
  68. 使うことができる若干のツーリング機能を提供します。
  69. このプロバイダ・インターフェースを実装することの割り切った性質によって、
  70. 開発者は機能/能力を「ワンストップサービス」で
  71. <classname>Zend_Tool_Framework</classname>に加えることができます。
  72. </para>
  73. <para>
  74. プロバイダ・インターフェースは空のインターフェースで、メソッドを強制しません。
  75. (これは、マーカ・インターフェース・パターンです):
  76. </para>
  77. <programlisting language="php"><![CDATA[
  78. interface Zend_Tool_Framework_Provider_Interface
  79. {}
  80. ]]></programlisting>
  81. <para>
  82. あるいは、もし望めば、<classname>Zend_Tool_Framework_Registry</classname>に
  83. アクセスできるようにする基底(または抽象)プロバイダを実装できます。:
  84. </para>
  85. <programlisting language="php"><![CDATA[
  86. abstract class Zend_Tool_Framework_Provider_Abstract
  87. implements Zend_Tool_Framework_Provider_Interface,
  88. Zend_Tool_Registry_EnabledInterface
  89. {
  90. protected $_registry;
  91. public function setRegistry(
  92. Zend_Tool_Framework_Registry_Interface $registry
  93. );
  94. }
  95. ]]></programlisting>
  96. </sect2>
  97. <sect2 id="zend.tool.framework.architecture.loaders">
  98. <title>ローダ</title>
  99. <para>
  100. ローダの目的は、<classname>Zend_Tool_Framework_Provider_Interface</classname>か
  101. <classname>Zend_Tool_Framework_Manifest_Interface</classname>を実装するクラスを含む
  102. プロバイダとマニフェスト・ファイルを見つけることです。
  103. 一旦これらのファイルがローダによって見つかると、
  104. プロバイダはプロバイダ・リポジトリにロードされ、
  105. マニフェスト・メタデータはマニフェスト・リポジトリにロードされます。
  106. </para>
  107. <para>
  108. ローダを実装するために、以下の抽象クラスを拡張しなければなりません:
  109. </para>
  110. <programlisting language="php"><![CDATA[
  111. abstract class Zend_Tool_Framework_Loader_Abstract
  112. {
  113. abstract protected function _getFiles();
  114. public function load()
  115. {
  116. /** ... */
  117. }
  118. }
  119. ]]></programlisting>
  120. <para>
  121. <methodname>_getFiles()</methodname>メソッドは、ファイル(絶対パス)の配列を返さなければなりません。
  122. Zend Frameworkで供給されるビルトイン・ローダは、インクルードパス・ローダと呼ばれます。
  123. デフォルトで、ツーリング・フレームワークは、
  124. プロバイダまたはマニフェスト・メタデータ・オブジェクトを含むかもしれないファイルを見つけるために、
  125. include_pathベースのローダを使います。
  126. 他のオプションが全く無くても、
  127. <classname>Zend_Tool_Framework_Loader_IncludePathLoader</classname>はインクルードパスの中で
  128. <filename>Mainfest.php</filename>、<filename>Tool.php</filename>または<filename>Provider.php</filename>で
  129. 終わるファイルを探します
  130. <classname>Zend_Tool_Framework_Loader_Abstract</classname>の<methodname>load()</methodname>メソッドによって一旦見つかると、
  131. それらがサポートされたインターフェースのいずれかを実装するかどうか判定するためにそれらはテストされます。
  132. もし実装していれば、見つかったクラスのインスタンスがインスタンス化されます、
  133. そして、それは固有のリポジトリを付加されています。
  134. </para>
  135. <programlisting language="php"><![CDATA[
  136. class Zend_Tool_Framework_Loader_IncludePathLoader
  137. extends Zend_Tool_Framework_Loader_Abstract
  138. {
  139. protected $_filterDenyDirectoryPattern = '.*(/|\\\\).svn';
  140. protected $_filterAcceptFilePattern = '.*(?:Manifest|Provider)\.php$';
  141. protected function _getFiles()
  142. {
  143. /** ... */
  144. }
  145. }
  146. ]]></programlisting>
  147. <para>
  148. ご覧の通り、インクルードパス・ローダは、<varname>$_filterAcceptFilePattern</varname>にマッチし、
  149. <varname>$_filterDenyDirectoryPattern</varname>にマッチしないファイルを求めて、
  150. すべてのinclude_pathsを検索します。
  151. </para>
  152. </sect2>
  153. <sect2 id="zend.tool.framework.architecture.manifests">
  154. <title>マニフェスト</title>
  155. <para>
  156. 要するに、マニフェストはプロバイダ・リポジトリにどんなさらなるプロバイダでもロードする役割を果たしうるばかりではなく、
  157. どんなプロバイダまたはクライアントにとってでも有用である、指定された、または任意のメタデータを含みます。
  158. </para>
  159. <para>
  160. 空の<classname>Zend_Tool_Framework_Manifest_Interface</classname>を実装して、
  161. <classname>Zend_Tool_Framework_Manifest_Metadata</classname>を実装する
  162. オブジェクトの配列を返す<methodname>getMetadata()</methodname>メソッドを提供しさえすれば、
  163. メタデータをマニフェスト・リポジトリにもたらすことができます。
  164. </para>
  165. <programlisting language="php"><![CDATA[
  166. interface Zend_Tool_Framework_Manifest_Interface
  167. {
  168. public function getMetadata();
  169. }
  170. ]]></programlisting>
  171. <para>
  172. 下記で定義されたローダによって、
  173. メタデータ・オブジェクトはマニフェスト・リポジトリ(<classname>Zend_Tool_Framework_Manifest_Repository</classname>)にロードされます。
  174. すべてのプロバイダがプロバイダ・リポジトリにロードされるとわかったあと、マニフェストは処理されます。
  175. これによって、何が現在プロバイダ・リポジトリ内部にあるかに基づくメタデータ・オブジェクトをマニフェストは作成できます。
  176. </para>
  177. <para>
  178. メタデータを記述するために用いることができる
  179. 多少の異なるメタデータ・クラスがあります。
  180. <classname>Zend_Tool_Framework_Manifest_Metadata</classname>は、
  181. 基底メタデータ・オブジェクトです。
  182. 以下のコード・スニペットによってわかるように、
  183. 基底メタデータ・クラスは事実上かなり軽量で抽象的です:
  184. </para>
  185. <programlisting language="php"><![CDATA[
  186. class Zend_Tool_Framework_Metadata_Basic
  187. {
  188. protected $_type = 'Global';
  189. protected $_name = null;
  190. protected $_value = null;
  191. protected $_reference = null;
  192. public function getType();
  193. public function getName();
  194. public function getValue();
  195. public function getReference();
  196. /** ... */
  197. }
  198. ]]></programlisting>
  199. <para>
  200. より分化したメタデータを記述するために同様に他のビルトイン・メタデータ・クラスがあります:
  201. <classname>ActionMetadata</classname>及び<classname>ProviderMetadata</classname>。
  202. これらのクラスは、アクションまたはプロバイダのいずれかに特有なメタデータをより詳細に記述する助けになります。
  203. そして、参照はそれぞれアクションまたはプロバイダへの参照であることが期待されます。
  204. これらのクラスは、以下のコード・スニペットで記述されます。
  205. </para>
  206. <programlisting language="php"><![CDATA[
  207. class Zend_Tool_Framework_Manifest_ActionMetadata
  208. extends Zend_Tool_Framework_Manifest_Metadata
  209. {
  210. protected $_type = 'Action';
  211. protected $_actionName = null;
  212. public function getActionName();
  213. /** ... */
  214. }
  215. class Zend_Tool_Framework_Manifest_ProviderMetadata
  216. extends Zend_Tool_Framework_Manifest_Metadata
  217. {
  218. protected $_type = 'Provider';
  219. protected $_providerName = null;
  220. protected $_actionName = null;
  221. protected $_specialtyName = null;
  222. public function getProviderName();
  223. public function getActionName();
  224. public function getSpecialtyName();
  225. /** ... */
  226. }
  227. ]]></programlisting>
  228. <para>
  229. これらのクラスでの'Type'は、
  230. オブジェクトが責を負うべきメタデータのタイプを記述するのに用いられます。
  231. <classname>ActionMetadata</classname>のケースでは、タイプは'Action'です。
  232. そして逆に、<classname>ProviderMetadata</classname>の場合は、タイプは'Provider'です。
  233. これらのメタデータ・タイプは、
  234. それらがこの新しいメタデータで参照しているオブジェクト(<methodname>getReference()</methodname>)だけでなく、
  235. それらが記述している「もの」についても、さらなる構造化情報を含みます。
  236. </para>
  237. <para>
  238. 基底<classname>Zend_Tool_Framework_Manifest_Metadata</classname>クラスを拡張して、
  239. クラス/オブジェクト・ローカル・マニフェストを通してこれらの新しいメタデータ・オブジェクトを返しさえすれば、
  240. あなた自身のメタデータ・タイプを構築できます。
  241. これらのユーザー・ベースのクラスは、マニフェスト・リポジトリの中に残ります
  242. </para>
  243. <para>
  244. もし、これらのメタデータ・オブジェクトがリポジトリならば、
  245. リポジトリでそれらを探すために利用できる2つの異なるメソッドがあります。
  246. </para>
  247. <programlisting language="php"><![CDATA[
  248. class Zend_Tool_Framework_Manifest_Repository
  249. {
  250. /**
  251. * 検索するメソッドを使うために、
  252. * $searchPropertiesはマニフェストの範囲内でマッチさせたい
  253. * キーと値のペアの名前と値を含まなければなりません。
  254. *
  255. * 例:
  256. * $manifestRepository->findMetadatas(array(
  257. * 'action' => 'Foo',
  258. * 'name' => 'cliActionName'
  259. * ));
  260. *
  261. * 値'Foo'と名前'action'でキーを持つどんなメタデータ・オブジェクトも見つけます。
  262. * そして、キーは'cliActionName'の'name'値と名づけられました。
  263. *
  264. * 注意:
  265. * 検索基準の中に存在するが、オブジェクトに現れない名前と値のペアを除外するか、
  266. * または含むために、$includeNonExistentPropertiesにブール値を渡してください
  267. */
  268. public function findMetadatas(Array $searchProperties = array(),
  269. $includeNonExistentProperties = true);
  270. /**
  271. * どれくらいが返されたかに関係なく、
  272. * マッチしている検索基準のうちのちょうど1つを以下は返します。
  273. * マニフェストの最初の1つは、何が返されるかということです。
  274. */
  275. public function findMetadata(Array $searchProperties = array(),
  276. $includeNonExistentProperties = true)
  277. {
  278. $metadatas = $this->getMetadatas($searchProperties,
  279. $includeNonExistentProperties);
  280. return array_shift($metadatas);
  281. }
  282. }
  283. ]]></programlisting>
  284. <para>
  285. 上記のサーチ方式を見ると、シグニチャはとても柔軟に検索することを許します。
  286. メタデータ・オブジェクトを見つけるために、
  287. 制約にマッチする配列を単に配列によって渡してください。
  288. データがプロパティ・アクセッサ
  289. (オブジェクト・メタデータの上で実装される<methodname>getSomething()</methodname>メソッド)
  290. によってアクセスできるならば、
  291. それは「見つかった」オブジェクト・メタデータとしてユーザーへ渡されます。
  292. </para>
  293. </sect2>
  294. <sect2 id="zend.tool.framework.architecture.clients">
  295. <title>クライアント</title>
  296. <para>
  297. クライアントは、<classname>Zend_Tool_Framework</classname>システムと
  298. ユーザーまたは外部ツールとの橋渡しをするインターフェースです。
  299. クライアントは、すべての形とサイズに伝わることができます:
  300. <acronym>RPC</acronym>エンドポイント、コマンド・ライン・インタフェースまたはウェブ・インターフェースさえ。
  301. Zend_Toolは、<classname>Zend_Tool_Framework</classname>システムと相互に作用するための
  302. デフォルト・インターフェースとして、コマンド・ライン・インタフェースを実装しました。
  303. </para>
  304. <para>
  305. クライアントを実装するためには、以下の抽象クラスを拡張する必要があります。:
  306. </para>
  307. <programlisting language="php"><![CDATA[
  308. abstract class Zend_Tool_Framework_Client_Abstract
  309. {
  310. /**
  311. * このメソッドは、カスタム・ローダ、リクエストとレスポンス・オブジェクトを構成して、
  312. * セットするために、クライアント実装によって実装されなければなりません。
  313. *
  314. * (必須ではありませんが、提案されます)
  315. */
  316. protected function _preInit();
  317. /**
  318. * このメソッドは解析するクライアント実装によって実装されなければなりません。
  319. * リクエスト・オブジェクト・アクション、
  320. * プロバイダ及びパラメータ情報を準備しなければなりません。
  321. */
  322. abstract protected function _preDispatch();
  323. /**
  324. * このメソッドは、レスポンス・オブジェクトを出力して、
  325. * それをツーリング・クライアントに(クライアントに特有の手段で)返すために、
  326. * クライアント実装によって実装されなければなりません。
  327. *
  328. * (必須ではありませんが、提案されます)
  329. */
  330. abstract protected function _postDispatch();
  331. }
  332. ]]></programlisting>
  333. <para>
  334. ご覧の通り、そこで、1つのメソッドはクライアントの必要を満たすことを要求されます。
  335. (他の2つは提案されます)
  336. 初期化、前処理と後処理
  337. コマンド・ライン・クライアントが動く方法についてより深く研究するには、
  338. <ulink
  339. url="http://framework.zend.com/svn/framework/standard/branches/release-1.8/library/Zend/Tool/Framework/Client/Console.php">ソースコード</ulink>
  340. を見てください。
  341. </para>
  342. </sect2>
  343. </sect1>