Zend_Gdata-Introduction.xml 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.gdata.introduction">
  5. <title>導入</title>
  6. <para>
  7. Google Data API は、Google のオンラインサービスに対するプログラマ向けのインターフェイスです。
  8. Google data Protocol は
  9. <ulink url="http://ietfreport.isoc.org/idref/draft-ietf-atompub-protocol/">Atom Publishing Protocol</ulink>
  10. に基づいており、クライアントアプリケーションからのデータの問い合わせ、
  11. データの投稿、更新、削除などを標準の HTTP
  12. と Atom syndication formation で行います。
  13. <classname>Zend_Gdata</classname> コンポーネントは PHP 5 用のインターフェイスで、Google Data
  14. に PHP からアクセスするためのものです。
  15. <classname>Zend_Gdata</classname> コンポーネントは、Atom Publishing Protocol
  16. を実装したその他のサービスへのアクセスもサポートしています。
  17. </para>
  18. <para>
  19. Google Data API についての詳細な情報は
  20. <ulink url="http://code.google.com/apis/gdata/">http://code.google.com/apis/gdata/</ulink>
  21. を参照ください。
  22. </para>
  23. <para>
  24. <classname>Zend_Gdata</classname> でアクセスできるサービスには次のようなものがあります。
  25. <itemizedlist>
  26. <listitem>
  27. <para>
  28. <link linkend="zend.gdata.calendar">Google Calendar</link>
  29. は、オンラインカレンダーアプリケーションです。
  30. </para>
  31. </listitem>
  32. <listitem>
  33. <para>
  34. <link linkend="zend.gdata.spreadsheets">Google Spreadsheets</link>
  35. は、オンラインで共同作業を行えるスプレッドシートツールです。
  36. アプリケーションで使用するデータの保存場所としても使用できます。
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. <link linkend="zend.gdata.docs">Google Documents List</link>
  42. は、その Google アカウントに保存されているすべてのスプレッドシートやワープロ文書、
  43. プレゼンテーションの一覧を取得します。
  44. </para>
  45. </listitem>
  46. <listitem>
  47. <para>
  48. <link linkend="zend.gdata.gapps">Google Provisioning</link>
  49. は、Google Apps がホストするドメイン上の
  50. ユーザアカウントやニックネーム、そしてメーリングリストの
  51. 作成、取得、更新、削除を行うものです。
  52. </para>
  53. </listitem>
  54. <listitem>
  55. <para>
  56. <link linkend="zend.gdata.gbase">Google Base</link>
  57. は、Google Base のアイテムを取得したり
  58. アイテムを投稿、更新、あるいは削除したりすることができます。
  59. </para>
  60. </listitem>
  61. <listitem>
  62. <para>
  63. <link linkend="zend.gdata.youtube">YouTube</link>
  64. は、動画やコメント、お気に入り、登録チャンネル、
  65. ユーザのプロファイルといった情報を検索して取得することができます。
  66. </para>
  67. </listitem>
  68. <listitem>
  69. <para>
  70. <link linkend="zend.gdata.photos">Picasa Web Albums</link>
  71. は、オンラインの写真共有アプリケーションです。
  72. </para>
  73. </listitem>
  74. <listitem>
  75. <para>
  76. <ulink url="http://code.google.com/apis/blogger/developers_guide_php.html">Google Blogger</ulink>
  77. は、人気のあるインターネットプロバイダです。
  78. "ボタンひとつで簡単に" 記事を配信することができます。
  79. </para>
  80. </listitem>
  81. <listitem>
  82. <para>
  83. Google CodeSearch
  84. を使用すると、さまざまなプロジェクトが公開しているソースコードを検索できます。
  85. </para>
  86. </listitem>
  87. <listitem>
  88. <para>
  89. Google Notebook
  90. は、メモ帳の内容を一般に公開することができます。
  91. </para>
  92. </listitem>
  93. </itemizedlist>
  94. </para>
  95. <note>
  96. <title>サポートしていないサービス</title>
  97. <para>
  98. <classname>Zend_Gdata</classname> には、これら以外の Google のサービス
  99. (例えば検索、Gmail、翻訳、マップなど)
  100. に対するインターフェイスは含まれていません。
  101. Google Data API をサポートしているサービスにのみ対応しています。
  102. </para>
  103. </note>
  104. <sect2 id="zend.gdata.introduction.structure">
  105. <title><classname>Zend_Gdata</classname> の構造</title>
  106. <para>
  107. <classname>Zend_Gata</classname> は、いくつかの型のクラスを組み合わせたものです。
  108. <itemizedlist>
  109. <listitem>
  110. <para>
  111. サービスクラス - これは <classname>Zend_Gdata_App</classname> を継承したものです。
  112. <classname>Zend_Gdata</classname> や <classname>Zend_Gdata_Spreadsheets</classname>
  113. といったその他のクラスもここに含まれます。
  114. これらのクラスは APP や GData サービス とのやり取りを行うもので、
  115. フィードを取得したりエントリを取得したり、
  116. あるいはエントリを投稿したり更新したり削除したりといったことができます。
  117. </para>
  118. </listitem>
  119. <listitem>
  120. <para>
  121. クエリクラス - これは <classname>Zend_Gdata_Query</classname> を継承したものです。
  122. 各サービス専用のクラス、たとえば <classname>Zend_Gdata_Spreadsheets_ListQuery</classname>
  123. や <classname>Zend_Gdata_Spreadsheets_CellQuery</classname> もここに含まれます。
  124. クエリクラスは、GData サービスからデータを取得するためのクエリを作成するものです。
  125. <code>setUpdatedMin()</code> や
  126. <code>setStartIndex()</code>、そして
  127. <code>getPublishedMin()</code> といったメソッドが存在します。
  128. クエリクラスには、出来上がったクエリの URL を生成するためのメソッド
  129. <code>getQueryUrl</code> もあります。
  130. また、<code>getQueryString()</code>
  131. メソッドを使用すると、URL のクエリ文字列部分を取得することができます。
  132. </para>
  133. </listitem>
  134. <listitem>
  135. <para>
  136. フィードクラス - これは <classname>Zend_Gdata_App_Feed</classname> を継承したものです。
  137. <classname>Zend_Gdata_Feed</classname> や
  138. <classname>Zend_Gdata_Spreadsheets_SpreadsheetFeed</classname>、
  139. <classname>Zend_Gdata_Spreadsheets_ListFeed</classname> といったその他のクラスもここに含まれます。
  140. これらのクラスはサービスから取得したエントリのフィードを表すものです。
  141. サービスから返されたデータを取得するために使用します。
  142. </para>
  143. </listitem>
  144. <listitem>
  145. <para>
  146. エントリクラス - これは <classname>Zend_Gdata_App_Entry</classname> を継承したものです。
  147. <classname>Zend_Gdata_Entry</classname> や <classname>Zend_Gdata_Spreadsheets_ListEntry</classname>
  148. といったその他のクラスもここに含まれます。
  149. これらのクラスは、サービスから取得したエントリを表すものです。また、
  150. サービスに送信するデータを作成するためにも用います。
  151. エントリのプロパティの値(たとえばスプレッドシートのセルの値など)
  152. を設定できるだけでなく、このオブジェクトを使用して
  153. 既存エントリの更新や削除のリクエストを送信することもできます。
  154. たとえば <code>$entry->save()</code>
  155. をコールすると、変更した内容を元のエントリに書き戻します。また
  156. <code>$entry->delete()</code> はそのエントリをサーバから削除します。
  157. </para>
  158. </listitem>
  159. <listitem>
  160. <para>
  161. その他のデータモデルクラス - これは
  162. <classname>Zend_Gdata_App_Extension</classname> を継承したものです。ここには、
  163. <classname>Zend_Gdata_App_Extension_Title</classname> (atom:title XML 要素を表します)
  164. や <classname>Zend_Gdata_Extension_When</classname> (GData Event "Kind" で使用する
  165. gd:when XML 要素を表します)、そして
  166. <classname>Zend_Gdata_Extension_Cell</classname> (Google Spreadsheets で使用する
  167. gs:cell XML 要素を表します) といったクラスが含まれます。
  168. これらのクラスは、サービスから取得したデータを保存したり
  169. サービスに送信するデータを構築したりするために用いるものです。
  170. プロパティへのアクセス用のメソッドが用意されています。たとえば
  171. <code>setText()</code> はその要素の子テキストノードの内容を設定し、
  172. <code>getText()</code> はその要素のテキストノードの内容を取得します。
  173. また <code>getStartTime()</code> は When 要素の開始時刻属性を取得します。
  174. そのほかにも同様のメソッドがあります。
  175. データモデルクラスには、その他のメソッドもあります。
  176. <code>getDOM()</code> は、その要素とすべての子要素を
  177. DOM 形式で表したものを返し、
  178. <code>transferFromDOM()</code> は
  179. DOM ツリーをもとにしたデータモデルを作成します。
  180. </para>
  181. </listitem>
  182. </itemizedlist>
  183. </para>
  184. </sect2>
  185. <sect2 id="zend.gdata.introduction.services">
  186. <title>Google サービスの使用法</title>
  187. <para>
  188. Google データサービスは、Atom Publishing Protocol (APP)
  189. および Atom syndication format に基づいたサービスです。
  190. <classname>Zend_Gdata</classname> コンポーネントを用いて APP や Google
  191. サービスを扱うには、<classname>Zend_Gdata_App</classname> や <classname>Zend_Gdata</classname>
  192. そして <classname>Zend_Gdata_Spreadsheets</classname> などのサービスクラスを使用する必要があります。
  193. サービスクラスには、サービスからデータのフィードを取得したり
  194. 新しいエントリをフィードに挿入したり
  195. 既存のエントリを更新したり削除したりといったメソッドがあります。
  196. </para>
  197. <para>
  198. 注意: <classname>Zend_Gdata</classname> を用いた実際に動作するサンプルプログラムが
  199. <code>demos/Zend/Gdata</code> ディレクトリにあります。
  200. このサンプルはコマンドラインで動かすように作られていますが、
  201. ウェブアプリケーション版にも簡単に書き換えられるでしょう。
  202. </para>
  203. </sect2>
  204. <sect2 id="zend.gdata.introdduction.magicfactory">
  205. <title><classname>Zend_Gdata</classname> クラスのインスタンスの取得</title>
  206. <para>
  207. Zend Framework の命名規約では、すべてのクラスは
  208. その存在位置のディレクトリ構造に基づいた名前をつける必要があります。
  209. たとえば Spreadsheets に関する拡張クラスは
  210. <code>Zend/Gdata/Spreadsheets/Extension/...</code> 配下に置かれ、
  211. その結果、クラス名は <classname>Zend_Gdata_Spreadsheets_Extension_...</classname>
  212. となります。ということは、スプレッドシートのセル要素のインスタンスを作成しようとしたら、
  213. 恐ろしく長い名前をタイプすることになるということです!
  214. </para>
  215. <para>
  216. ということで、すべてのサービスクラス
  217. (<classname>Zend_Gdata_App</classname>、<classname>Zend_Gdata</classname>、<classname>Zend_Gdata_Spreadsheets</classname> など)
  218. に特別なファクトリメソッドを用意するようにしました。
  219. これを用いることで、データモデルやクエリ、
  220. その他のクラスのインスタンスをより簡単に作成できるようになります。
  221. このファクトリメソッドは、マジックメソッド
  222. <code>__call</code> を用いて実装しています。このメソッドで、
  223. <code>$service->newXXX(arg1, arg2, ...)</code> というコールをすべて処理しています。
  224. XXX の値に基づいて、登録されているすべての 'パッケージ' からクラスを探します。
  225. 以下に例を示します。
  226. </para>
  227. <programlisting role="php"><![CDATA[
  228. $ss = new Zend_Gdata_Spreadsheets();
  229. // Zend_Gdata_App_Spreadsheets_CellEntry を作成します
  230. $entry = $ss->newCellEntry();
  231. // Zend_Gdata_App_Spreadsheets_Extension_Cell を作成します
  232. $cell = $ss->newCell();
  233. $cell->setText('My cell value');
  234. $cell->setRow('1');
  235. $cell->setColumn('3');
  236. $entry->cell = $cell;
  237. // ... $entry を使用して、Google Spreadsheet の内容を更新します
  238. ]]>
  239. </programlisting>
  240. <para>
  241. 継承ツリー内にある各サービス用クラス内で、
  242. 適切な 'パッケージ' (ディレクトリ) を登録します。
  243. ファクトリメソッドは、これを使用してクラスを探します。
  244. </para>
  245. </sect2>
  246. <sect2 id="zend.gdata.introduction.authentication">
  247. <title>Google Data クライアント認証</title>
  248. <para>
  249. ほとんどの Google Data サービスは、
  250. 個人データへのアクセスやデータの保存、削除の前に
  251. Google サーバに対する認証を要求します。
  252. Google Data の認証用に提供される実装は
  253. <link linkend="zend.gdata.authsub">AuthSub</link> および
  254. <link linkend="zend.gdata.clientlogin">ClientLogin</link>
  255. の二種類があります。
  256. <classname>Zend_Gdata</classname> ではこれら両方の方式に対するインターフェイスを用意しています。
  257. </para>
  258. <para>
  259. Google Data サービスに対するその他大半の問い合わせは、
  260. 認証を必要としません。
  261. </para>
  262. </sect2>
  263. <sect2 id="zend.gdata.introduction.dependencies">
  264. <title>依存性</title>
  265. <para>
  266. <classname>Zend_Gdata</classname> は
  267. <link linkend="zend.http.client">Zend_Http_Client</link>
  268. を用いてリクエストを google.com に送信し、結果を取得します。
  269. ほとんどの Google Data リクエストに対する応答は
  270. <classname>Zend_Gdata_App_Feed</classname> あるいは <classname>Zend_Gdata_App_Entry</classname>
  271. クラスのサブクラスで返されます。
  272. </para>
  273. <para>
  274. <classname>Zend_Gdata</classname> は、PHP アプリケーションの稼動しているホストが
  275. インターネットに直接つながっていることを想定しています。
  276. <classname>Zend_Gdata</classname> クライアントは Google Data サーバへの接続を行います。
  277. </para>
  278. </sect2>
  279. <sect2 id="zend.gdata.introduction.creation">
  280. <title>新しい Gdata クライアントの作成</title>
  281. <para>
  282. <classname>Zend_Gdata_App</classname> クラス、<classname>Zend_Gdata</classname> クラス、
  283. あるいはそのサブクラスのひとつのオブジェクトを作成します。
  284. 各サブクラスではサービス固有のヘルパーメソッドを提供します。
  285. </para>
  286. <para>
  287. <classname>Zend_Gdata_App</classname> のコンストラクタに渡すオプションの引数は
  288. <link linkend="zend.http.client">Zend_Http_Client</link>
  289. のインスタンスです。このパラメータを渡さなかった場合は、
  290. <classname>Zend_Gdata</classname> はデフォルトの <classname>Zend_Http_Client</classname> オブジェクトを作成します。
  291. これには、プライベートフィードにアクセスするための認証データは設定されていません。
  292. <classname>Zend_Http_Client</classname> オブジェクトを自分で指定すると、
  293. クライアントオブジェクトに対する設定オプションを指定することができます。
  294. </para>
  295. <programlisting role="php"><![CDATA[
  296. $client = new Zend_Http_Client();
  297. $client->setConfig( ...オプション... );
  298. $gdata = new Zend_Gdata($client);
  299. ]]>
  300. </programlisting>
  301. <para>
  302. Zend Framework 1.7 以降、プロトコルのバージョン管理のサポートが追加されました。
  303. これにより、クライアントおよびサーバで新機能をサポートしつつ、
  304. 過去との互換性を保持できるようになります。
  305. ほとんどのサービスはバージョン管理を自前で行う必要はありませんが、
  306. <classname>Zend_Gdata</classname> のインスタンスを直接作成する場合 (サブクラスを使わない場合)
  307. は、必要なプロトコルのバージョンを指定してサーバの機能にアクセスする必要があります。
  308. </para>
  309. <programlisting role="php"><![CDATA[
  310. $client = new Zend_Http_Client();
  311. $client->setConfig( ...オプション... );
  312. $gdata = new Zend_Gdata($client);
  313. $gdata->setMajorProtocolVersion(2);
  314. $gdata->setMinorProtocolVersion(null);
  315. ]]>
  316. </programlisting>
  317. <para>
  318. 認証済みの <classname>Zend_Http_Client</classname> オブジェクトを作成する方法については、
  319. 認証のセクションも参照ください。
  320. </para>
  321. </sect2>
  322. <sect2 id="zend.gdata.introduction.parameters">
  323. <title>共通のクエリパラメータ</title>
  324. <para>
  325. パラメータを指定することで、<classname>Zend_Gdata</classname>
  326. での問い合わせをカスタマイズすることができます。
  327. クエリのパラメータは、 <classname>Zend_Gdata_Query</classname>
  328. のサブクラスを使用して指定します。
  329. <classname>Zend_Gdata_Query</classname> クラスにはクエリパラメータを設定するメソッドが含まれ、
  330. これを用いて GData サービスにアクセスします。
  331. たとえば Spreadsheets のような個々のサービスでも
  332. クエリクラスを用意しており、そのサービスやフィードに合わせた独自のパラメータを定義しています。
  333. Spreadsheets の CellQuery クラスは Cell Feed
  334. に対する問い合わせを行い、ListQuery クラスは
  335. List Feed に対する問い合わせを行います。
  336. それぞれのフィードに対して別々のパラメータを指定することができます。
  337. GData 全体で使用できるパラメータについて、
  338. 以下で説明します。
  339. </para>
  340. <itemizedlist>
  341. <listitem>
  342. <para>
  343. <code>q</code> パラメータはテキストのクエリ文字列を指定します。
  344. パラメータの値は文字列となります。
  345. </para>
  346. <para>
  347. このパラメータを設定するには <code>setQuery()</code>
  348. 関数を使用します。
  349. </para>
  350. </listitem>
  351. <listitem>
  352. <para>
  353. <code>alt</code> パラメータはフィードの形式を指定します。
  354. このパラメータには
  355. <code>atom</code>、
  356. <code>rss</code>、
  357. <code>json</code>、
  358. あるいは <code>json-in-script</code> のいずれかを指定します。
  359. このパラメータを指定しなかった場合、デフォルトのフィードの形式は
  360. <code>atom</code> となります。
  361. 注意: <classname>Zend_Gdata</classname> で処理できるのは、
  362. atom フィード形式の出力だけであることに注意しましょう。
  363. <classname>Zend_Http_Client</classname> を使用するとその他の形式のフィードも取得することができます。
  364. その際は、<classname>Zend_Gdata_Query</classname>
  365. クラスやそのサブクラスが作成したクエリ URL を使用します。
  366. </para>
  367. <para>
  368. このパラメータを設定するには <code>setAlt()</code>
  369. 関数を使用します。
  370. </para>
  371. </listitem>
  372. <listitem>
  373. <para>
  374. <code>maxResults</code> パラメータはフィード内のエントリ数を制限します。
  375. 整数値を指定します。返されるフィード内のエントリの数は、
  376. この値を超えることはありません。
  377. </para>
  378. <para>
  379. このパラメータを設定するには <code>setMaxResults()</code>
  380. 関数を使用します。
  381. </para>
  382. </listitem>
  383. <listitem>
  384. <para>
  385. <code>startIndex</code> パラメータは、
  386. フィードで返される最初のエントリの番号を指定します。
  387. それ以前の番号のエントリは読み飛ばされます。
  388. </para>
  389. <para>
  390. このパラメータを設定するには <code>setStartIndex()</code>
  391. 関数を使用します。
  392. </para>
  393. </listitem>
  394. <listitem>
  395. <para>
  396. <code>updatedMin</code> パラメータおよび <code>updatedMax</code>
  397. パラメータは、エントリの日付の範囲を指定します。
  398. <code>updatedMin</code> を指定すると、
  399. それより前に更新されたエントリはフィードに含まれません。
  400. 同様に、<code>updatedMax</code>
  401. で指定した日付より後で更新されたエントリもフィードに含まれません。
  402. </para>
  403. <para>
  404. これらのパラメータには、タイムスタンプを表す数値を指定します。
  405. あるいは 日付/時刻 を表す文字列を指定することもできます。
  406. </para>
  407. <para>
  408. これらのパラメータを設定するには <code>setUpdatedMin()</code>
  409. および <code>setUpdatedMax()</code> 関数を使用します。
  410. </para>
  411. </listitem>
  412. </itemizedlist>
  413. <para>
  414. これらの <code>set</code> 関数に対応する
  415. <code>get</code> 関数もあります。
  416. </para>
  417. <programlisting role="php"><![CDATA[
  418. $query = new Zend_Gdata_Query();
  419. $query->setMaxResults(10);
  420. echo $query->getMaxResults(); // 10 を返します
  421. ]]>
  422. </programlisting>
  423. <para>
  424. <classname>Zend_Gdata</classname> クラスでは、
  425. 特別なゲッターメソッドおよびセッターメソッドも実装しています。
  426. つまり、パラメータの名前をクラスの仮想的なメンバとして扱うことができます。
  427. </para>
  428. <programlisting role="php"><![CDATA[
  429. $query = new Zend_Gdata_Query();
  430. $query->maxResults = 10;
  431. echo $query->maxResults; // 10 を返します
  432. ]]>
  433. </programlisting>
  434. <para>
  435. すべてのパラメータを消去するには <code>resetParameters()</code>
  436. を使用します。複数のクエリで <classname>Zend_Gdata</classname>
  437. を使いまわす場合などに便利です。
  438. </para>
  439. <programlisting role="php"><![CDATA[
  440. $query = new Zend_Gdata_Query();
  441. $query->maxResults = 10;
  442. // ...フィードを取得します...
  443. $gdata->resetParameters(); // すべてのパラメータを消去します
  444. // ...別のフィードを取得します...
  445. ]]>
  446. </programlisting>
  447. </sect2>
  448. <sect2 id="zend.gdata.introduction.getfeed">
  449. <title>フィードの取得</title>
  450. <para>
  451. <code>getFeed()</code> を使用して、指定した URI からフィードを取得します。
  452. この関数は、getFeed の二番目の引数で指定したクラスのインスタンスを返します。
  453. このクラスのデフォルトは <classname>Zend_Gdata_Feed</classname> です。
  454. </para>
  455. <programlisting role="php"><![CDATA[
  456. $gdata = new Zend_Gdata();
  457. $query = new Zend_Gdata_Query(
  458. 'http://www.blogger.com/feeds/blogID/posts/default');
  459. $query->setMaxResults(10);
  460. $feed = $gdata->getFeed($query);
  461. ]]>
  462. </programlisting>
  463. <para>
  464. この後の節で、各 Google Data
  465. サービス用のヘルパークラス固有の関数について説明します。これらの関数により、
  466. 対応するサービスにあわせた適切な URI からフィードを取得できるようになります。
  467. </para>
  468. </sect2>
  469. <sect2 id="zend.gdata.introduction.paging">
  470. <title>複数ページのフィードの扱い方</title>
  471. <para>
  472. 多くのエントリが含まれるフィードを取得した場合、
  473. そのフィードはいくつかの「ページ」に分かれていることがあるかもしれません。
  474. そのような場合には、各ページには次のページへのリンクが含まれることになります。
  475. このリンクにアクセスするには
  476. <code>getLink('next')</code> を使用します。
  477. この例は、フィードの次のページを取得する方法を示すものです。
  478. </para>
  479. <programlisting role="php"><![CDATA[
  480. function getNextPage($feed) {
  481. $nextURL = $feed->getLink('next');
  482. if ($nextURL !== null) {
  483. return $gdata->getFeed($nextURL);
  484. } else {
  485. return null;
  486. }
  487. }
  488. ]]>
  489. </programlisting>
  490. <para>
  491. もしこのようにページに分かれているのが気に入らない場合は、
  492. フィードの最初のページを
  493. <classname>Zend_Gdata_App::retrieveAllEntriesForFeed()</classname>
  494. に渡しましょう。そうすると、
  495. すべてのエントリの内容をひとつのフィードにまとめてくれます。
  496. この関数の使用法を、次の例で示します。
  497. </para>
  498. <programlisting role="php"><![CDATA[
  499. $gdata = new Zend_Gdata();
  500. $query = new Zend_Gdata_Query(
  501. 'http://www.blogger.com/feeds/blogID/posts/default');
  502. $feed = $gdata->retrieveAllEntriesForFeed($gdata->getFeed($query));
  503. ]]>
  504. </programlisting>
  505. <para>
  506. 大きなフィードに対してこの関数をコールすると、
  507. 処理に時間がかかるということに注意しましょう。
  508. <code>set_time_limit()</code>
  509. で PHP の実行時間制限を拡大する必要があるかもしれません。
  510. </para>
  511. </sect2>
  512. <sect2 id="zend.gdata.introduction.usefeedentry">
  513. <title>フィードやエントリ内のデータの操作</title>
  514. <para>
  515. フィードを取得したら、次はそのデータを読み込んだり
  516. そこに含まれるエントリを読み込んだりする番です。
  517. これには各データモデルクラスのアクセス用メソッドを使用するか、
  518. あるいはマジックメソッドを使用します。以下に例を示します。
  519. </para>
  520. <programlisting role="php"><![CDATA[
  521. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  522. $gdata = new Zend_Gdata($client);
  523. $query = new Zend_Gdata_Query(
  524. 'http://www.blogger.com/feeds/blogID/posts/default');
  525. $query->setMaxResults(10);
  526. $feed = $gdata->getFeed($query);
  527. foreach ($feed as $entry) {
  528. // マジックメソッドを使用します
  529. echo 'Title: ' . $entry->title->text;
  530. // 定義されているアクセス用メソッドを使用します
  531. echo 'Content: ' . $entry->getContent()->getText();
  532. }
  533. ]]>
  534. </programlisting>
  535. </sect2>
  536. <sect2 id="zend.gdata.introduction.updateentry">
  537. <title>エントリの更新</title>
  538. <para>
  539. エントリを取得したら、それを更新してサーバに保存することができます。以下に例を示します。
  540. </para>
  541. <programlisting role="php"><![CDATA[
  542. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  543. $gdata = new Zend_Gdata($client);
  544. $query = new Zend_Gdata_Query(
  545. 'http://www.blogger.com/feeds/blogID/posts/default');
  546. $query->setMaxResults(10);
  547. $feed = $gdata->getFeed($query);
  548. foreach ($feed as $entry) {
  549. // タイトルに 'NEW' を追加します
  550. echo 'Old Title: ' . $entry->title->text;
  551. $entry->title->text = $entry->title->text . ' NEW';
  552. // エントリの内容を更新します
  553. $newEntry = $entry->save();
  554. echo 'New Title: ' . $newEntry->title->text;
  555. }
  556. ]]>
  557. </programlisting>
  558. </sect2>
  559. <sect2 id="zend.gdata.introduction.post">
  560. <title>Google サーバへのエントリの送信</title>
  561. <para>
  562. <classname>Zend_Gdata</classname> オブジェクトの関数 <code>insertEntry()</code>
  563. にアップロードしたいデータを指定し、
  564. 新しいエントリを Google Data サービスに保存します。
  565. </para>
  566. <para>
  567. 各サービス用のデータモデルクラスを使用して適切なエントリを作成し、
  568. Google のサービスに投稿することができます。
  569. <code>insertEntry()</code> 関数には、
  570. <classname>Zend_Gdata_App_Entry</classname> の子クラスに投稿内容を格納して渡します。
  571. このメソッドは <classname>Zend_Gdata_App_Entry</classname> の子クラスを返します。
  572. これは、サーバから返されたエントリの状態を表します。
  573. </para>
  574. <para>
  575. もうひとつの方法として、そのエントリの内容を
  576. XML 構造の文字列として作成して
  577. <code>insertEntry()</code> 関数に渡すこともできます。
  578. </para>
  579. <programlisting role="php"><![CDATA[
  580. $gdata = new Zend_Gdata($authenticatedHttpClient);
  581. $entry = $gdata->newEntry();
  582. $entry->title = $gdata->newTitle('Playing football at the park');
  583. $content =
  584. $gdata->newContent('We will visit the park and play football');
  585. $content->setType('text');
  586. $entry->content = $content;
  587. $entryResult = $gdata->insertEntry($entry,
  588. 'http://www.blogger.com/feeds/blogID/posts/default');
  589. echo 'この結果のエントリの <id> は、' . $entryResult->id->text;
  590. ]]>
  591. </programlisting>
  592. <para>
  593. エントリを送信するには、認証済みの <classname>Zend_Http_Client</classname>
  594. を使用する必要があります。これは、
  595. <classname>Zend_Gdata_AuthSub</classname> クラスあるいは
  596. <classname>Zend_Gdata_ClientLogin</classname> クラスを使用して作成します。
  597. </para>
  598. </sect2>
  599. <sect2 id="zend.gdata.introduction.delete">
  600. <title>Google サーバからのデータの削除</title>
  601. <para>
  602. 方法 1: <classname>Zend_Gdata</classname> オブジェクトの関数 <code>delete()</code>
  603. に削除したいエントリを指定して、Google Data
  604. サービスからデータを削除します。
  605. フィードエントリの編集用 URL を
  606. <code>delete()</code> メソッドに渡します。
  607. </para>
  608. <para>
  609. 方法 2: あるいは、Google サービスから取得したエントリに対して
  610. <code>$entry->delete()</code> をコールすることもできます。
  611. </para>
  612. <programlisting role="php"><![CDATA[
  613. $gdata = new Zend_Gdata($authenticatedHttpClient);
  614. // Google Data のフィード
  615. $feedUri = ...;
  616. $feed = $gdata->getFeed($feedUri);
  617. foreach ($feed as $feedEntry) {
  618. // 方法 1 - エントリを直接削除します
  619. $feedEntry->delete();
  620. // 方法 2 - 編集用 URL を $gdata->delete()
  621. // に渡してエントリを削除します
  622. // $gdata->delete($feedEntry->getEditLink()->href);
  623. }
  624. ]]>
  625. </programlisting>
  626. <para>
  627. エントリを削除するには、認証済みの <classname>Zend_Http_Client</classname>
  628. を使用する必要があります。これは、
  629. <classname>Zend_Gdata_AuthSub</classname> クラスあるいは
  630. <classname>Zend_Gdata_ClientLogin</classname> クラスを使用して作成します。
  631. </para>
  632. </sect2>
  633. </sect1>