Zend_Gdata_Gbase.xml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15742 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.gdata.gbase">
  5. <title>Google Base verwenden</title>
  6. <para>
  7. Die Google Base Daten API wurde entwickelt um Entwicklern zwei Dinge zu gestatten:
  8. <itemizedlist>
  9. <listitem>
  10. <para>
  11. Google Base Daten abzufragen um Anwendungen und Mashups zu erstellen.
  12. </para>
  13. </listitem>
  14. <listitem>
  15. <para>
  16. Google Base Elemente einzugeben und programtechnisch handzuhaben.
  17. </para>
  18. </listitem>
  19. </itemizedlist>
  20. </para>
  21. <para>
  22. Es gibt zwei Feeds an Elementen: Feed Fetzen und benutzerdefinierte Feeds für Elemente. Der
  23. Feed Fetzen enthält alle Google Base Daten und ist für jeden lesbar um Abfragen darauf
  24. durchzuführen ohne der Notwendigkeit sich zu Authentifizieren. Der benutzerdefinierte Feed
  25. für Elemente ist ein benutzer spezifisches Subset an Daten und nur ein Benutzer/Eigentümer
  26. kann auf diesen Feed zugreifen um eigene Daten einzufügen, zu aktualisieren oder zu löschen.
  27. Abfragen werden für beide Typen von Feeds auf dem selben Weg erstellt.
  28. </para>
  29. <para>
  30. Siehe <ulink
  31. url="http://code.google.com/apis/base/">http://code.google.com/apis/base</ulink> für
  32. weitere Informationen über die Google Base API.
  33. </para>
  34. <sect2 id="zend.gdata.gbase.connect">
  35. <title>Verbinden zum Base Service</title>
  36. <para>
  37. Die Google Base API basiert, wie alle GData APIs, auf dem Atom Publishing Protokoll
  38. (APP), einem XML basierenden Format für gemanagte Web-basierende Ressourcen. Der Verkehr
  39. zwischen einem Client und den Google Base Servern findet über HTTP statt, und erlaubt
  40. sowohl authentifizierte als auch nicht authentifizierte Verbindungen.
  41. </para>
  42. <para>
  43. Bevor irgendeine Transaktion stattfinden kann, muß diese Verbindung hergestellt werden.
  44. Das Erstellen einer Verbindung zu den Base Server enthält zwei Schritte: Erstellen eines
  45. HTTP Clients und das Binden einer <classname>Zend_Gdata_Gbase</classname> Serviceinstanz
  46. an diesen Client.
  47. </para>
  48. <sect3 id="zend.gdata.gbase.connect.authentication">
  49. <title>Authentifizierung</title>
  50. <para>
  51. Die Google Base API erlaubt Zugriff auf beide, sowohl öffentliche als auch private
  52. Base Feeds. Öffentliche Feeds benötigen keine Authentifizierung, sind aber nur
  53. lesbar und bieten nur reduzierte Funktionalität. Private Feeds bieten die größte
  54. Funktionalität benötigen aber eine authentifizierte Verbindung zu den Base Servern.
  55. Es gibt drei authentifizierung Schematas die von Google Base unterstützt werden:
  56. </para>
  57. <itemizedlist>
  58. <listitem>
  59. <para>
  60. <firstterm>ClientAuth</firstterm>
  61. bietet dirakte Benutzername/Passwort Authentifizierung zu den Base Servern.
  62. Da es dieses Schema notwendig macht das Benutzer die Anwendung mit Ihrem
  63. Passwort versorgen, ist diese Authentifizierung nur dann notwendig wenn
  64. andere Authentifizierung Schemata unzureichend sind.
  65. </para>
  66. </listitem>
  67. <listitem>
  68. <para>
  69. <firstterm>AuthSub</firstterm>
  70. erlaubt die Authentifizierung zu den Base Servern über einen Google Proxy
  71. Server. Das bietet das gleiche Level an Bequemlichkeit wie ClientAuth, aber
  72. ohne die Sicherheitsrisiken was es zu einer idealen Wahl für Web-basierte
  73. Anwendungen macht.
  74. </para>
  75. </listitem>
  76. </itemizedlist>
  77. <para>
  78. Die <classname>Zend_Gdata</classname> Bibliothek bietet Unterstützung für alle drei
  79. Authentifizierungs Schemata. Im Rest dieses Kapitels wird angenommen das man mit den
  80. Authentifizierungs Schemata umgehen kann und wie eine notwendige Authentifizierte
  81. Verbindung erstellt wird. Für weitere Informationen kann in das Kapitel <xref
  82. linkend="zend.gdata.introduction.authentication" /> oder die <ulink
  83. url="http://code.google.com/apis/gdata/auth.html">Übersicht der
  84. Authentifizierung im Entwickler Guide der Google Data API</ulink>
  85. gesehen werden.
  86. </para>
  87. </sect3>
  88. <sect3 id="zend.gdata.gbase.connect.service">
  89. <title>Eine Service Instanz erstellen</title>
  90. <para>
  91. Im mit Google Base zu interagieren, bietet diese Bibliothek die
  92. <classname>Zend_Gdata_Gbase</classname> Service Klasse. Diese klasse bietet ein
  93. standardmäßiges Interface zu Google Data und den Atom Publishing Protokoll Modellen
  94. und unterstützt in der Durchführung von Anfragen von und zu den Base Servern.
  95. </para>
  96. <para>
  97. Sobald ein Authentifizierungs Schema ausgewählt wurde, besteht der nächste Schritt
  98. darin eine Instanz von <classname>Zend_Gdata_Gbase</classname> zu erstellen. Diese
  99. Klasse nimmt eine Instanz von <classname>Zend_Http_Client</classname> als einziges
  100. Argument. Das bietet ein Interface für AuthSub und ClientAuth Authentifizierungen,
  101. da beide einen speziellen authentifizierten HTTP Client für die Erstellung
  102. benötigen. Wenn keine Argumente angegeben wurden, wird automatisch eine nicht
  103. authentifizierte Instanz von <classname>Zend_Http_Client</classname> erstellt.
  104. </para>
  105. <para>
  106. Das nachfolgende Beispiel zeigt wir eine Base Service Klasse erstellt wird indem die
  107. ClientAuth Authentifizierung verwendet wird:
  108. </para>
  109. <programlisting language="php"><![CDATA[
  110. // Parameter für die ClientAuth Authentifizierung
  111. $service = Zend_Gdata_Gbase::AUTH_SERVICE_NAME;
  112. $user = "sample.user@gmail.com";
  113. $pass = "pa$$w0rd";
  114. // Erstellt einen authentifizierten HTTP Client
  115. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  116. // Erstellt eine Instanz des Base Services
  117. $service = new Zend_Gdata_Gbase($client);
  118. ]]></programlisting>
  119. <para>
  120. Ein Base Service der AuthSub verwendet kann ähnlich erstellt werden, durch einen
  121. etwas längeren Code:
  122. </para>
  123. <programlisting language="php"><![CDATA[
  124. /*
  125. * Empfängt die aktuelle URL so das der AuthSub Server weiß wohin er
  126. * umleiten soll nachdem die Authentifizierung des Benutzers vollständig ist.
  127. */
  128. function getCurrentUrl()
  129. {
  130. global $_SERVER;
  131. // Filtert php_self um Sicherheits Risiken zu vermeiden
  132. $php_request_uri =
  133. htmlentities(substr($_SERVER['REQUEST_URI'],
  134. 0,
  135. strcspn($_SERVER['REQUEST_URI'], "\n\r")),
  136. ENT_QUOTES);
  137. if (isset($_SERVER['HTTPS']) &&
  138. strtolower($_SERVER['HTTPS']) == 'on') {
  139. $protocol = 'https://';
  140. } else {
  141. $protocol = 'http://';
  142. }
  143. $host = $_SERVER['HTTP_HOST'];
  144. if ($_SERVER['HTTP_PORT'] != '' &&
  145. (($protocol == 'http://' && $_SERVER['HTTP_PORT'] != '80') ||
  146. ($protocol == 'https://' && $_SERVER['HTTP_PORT'] != '443'))) {
  147. $port = ':' . $_SERVER['HTTP_PORT'];
  148. } else {
  149. $port = '';
  150. }
  151. return $protocol . $host . $port . $php_request_uri;
  152. }
  153. /**
  154. * Einen AuthSub authentifizierten HTTP Client erhalten, und den Benutzer zum
  155. * AuthSub Server umleiten um sich anzumelden wenn das notwendig ist.
  156. */
  157. function getAuthSubHttpClient()
  158. {
  159. global $_SESSION, $_GET;
  160. // Wenn es keine AuthSub Session gibt oder kein Einmal-Token auf uns wartet,
  161. // den Benutzer zum AuthSub Server umleiten um eine zu erhalten.
  162. if (!isset($_SESSION['sessionToken']) && !isset($_GET['token'])) {
  163. // Parameter für den AuthSub Server
  164. $next = getCurrentUrl();
  165. $scope = "http://www.google.com/base/feeds/items/";
  166. $secure = false;
  167. $session = true;
  168. // Den Benutzer zum AuthSub Server umleiten um sich anzumelden
  169. $authSubUrl = Zend_Gdata_AuthSub::getAuthSubTokenUri($next,
  170. $scope,
  171. $secure,
  172. $session);
  173. header("HTTP/1.0 307 Temporary redirect");
  174. header("Location: " . $authSubUrl);
  175. exit();
  176. }
  177. // Konvertiert einen AuthSub Einmal-Token in einen Session-Token wenn das notwendig ist
  178. if (!isset($_SESSION['sessionToken']) && isset($_GET['token'])) {
  179. $_SESSION['sessionToken'] =
  180. Zend_Gdata_AuthSub::getAuthSubSessionToken($_GET['token']);
  181. }
  182. // An diesem Punkt sind wir durch AuthSub authentifiziert und können eine
  183. // authentifizierte Instanz des HTTP Clients erhalten
  184. // Erstellt einen authentifizierten HTTP Client
  185. $client = Zend_Gdata_AuthSub::getHttpClient($_SESSION['sessionToken']);
  186. return $client;
  187. }
  188. // -> Script Ausführung beginnt hier <-
  189. // http://code.google.com/apis/gdata/reference.html#Queries
  190. // Sicherstellen das der Benutzer eine gültige Session hat sodas wir die
  191. // AuthSub Session aufnehmen können sobald diese vorhanden ist.
  192. session_start();
  193. // Erstellt eine Instanz des Base Services, leitet den Benutzer zum AuthSub Server um
  194. // wenn das notwendig ist.
  195. $service = new Zend_Gdata_Gbase(getAuthSubHttpClient());
  196. ]]></programlisting>
  197. <para>
  198. Letztendlich kann ein nicht authentifizierter Server erstellt werden für die
  199. Verwendung mit Feed Fetzen:
  200. </para>
  201. <programlisting language="php"><![CDATA[
  202. // Erstellt eine Instanz des Base Services und verwendet einen nicht authentifizierten HTTP Client
  203. $service = new Zend_Gdata_Gbase();
  204. ]]></programlisting>
  205. </sect3>
  206. </sect2>
  207. <sect2 id="zend.gdata.gbase.retrieve">
  208. <title>Elemente empfangen</title>
  209. <para>
  210. Benutzerdefinierte Feeds oder Feed Fetzen können abgefragt werden um Elemente zu
  211. erhalten. Es benötigt zwei Schritte um eine Abfrage zu senden und über den
  212. zurückgegebenen Feed zu iterieren.
  213. </para>
  214. <sect3 id="zend.gdata.gbase.retrieve.query">
  215. <title>Eine strukturierte Anfrage senden</title>
  216. <para>
  217. Eine strukturierte Anfrage kann gesendet werden um Elemente vom eigenen
  218. benutzerdefinierten Feed oder von einem öffentlichen Feed Fetzen zu erhalten.
  219. </para>
  220. <para>
  221. Wenn Elemente empfangen werden indem die Base API verwendet wird, werden speziell
  222. konstruierte Abfrage URLs verwendet um zu beschreiben welche Evente zurückgegeben
  223. werden sollen. Die <classname>Zend_Gdata_Gbase_ItemQuery</classname> und
  224. <classname>Zend_Gdata_Gbase_SnippetQuery</classname> Klassen vereinfachen diese
  225. Aufgabe durch die automatische Erstellung einer Anfrage URL basierend auf den
  226. angegebenen Parametern.
  227. </para>
  228. <sect4 id="zend.gdata.gbase.retrieve.query.customeritems">
  229. <title>Benutzerdefinierte Feed Elemente Anfragen</title>
  230. <para>
  231. Um eine Abfrage auf Benutzerdefinierte Feed Elemente durchzuführen, gibt es die
  232. <code>newItemQuery()</code> und <code>getGbaseItemFeed()</code> Methoden:
  233. </para>
  234. <programlisting language="php"><![CDATA[
  235. $service = new Zend_Gdata_Gbase($client);
  236. $query = $service->newItemQuery();
  237. $query->setBq('[title:Programming]');
  238. $query->setOrderBy('modification_time');
  239. $query->setSortOrder('descending');
  240. $query->setMaxResults('5');
  241. $feed = $service->getGbaseItemFeed($query);
  242. ]]></programlisting>
  243. <para>
  244. Eine komplette Liste dieser Parameter ist im <ulink
  245. url="http://code.google.com/apis/base/items-feed.html#QueParameters">Abfrage
  246. Parameter Kapitel</ulink> der Benutzerdefinierten Feed Elemente
  247. Dokumentation vorhanden.
  248. </para>
  249. </sect4>
  250. <sect4 id="zend.gdata.gbase.retrieve.query.snippets">
  251. <title>Feed Fetzen abfragen</title>
  252. <para>
  253. Um eine Abfrage über öffentliche Feed Fetzen durchzuführen, gibt es die
  254. <code>newSnippetQuery()</code> und <code>getGbaseSnippetFeed()</code> Methoden:
  255. </para>
  256. <programlisting language="php"><![CDATA[
  257. $service = new Zend_Gdata_Gbase();
  258. $query = $service->newSnippetQuery();
  259. $query->setBq('[title:Programming]');
  260. $query->setOrderBy('modification_time');
  261. $query->setSortOrder('descending');
  262. $query->setMaxResults('5');
  263. $feed = $service->getGbaseSnippetFeed($query);
  264. ]]></programlisting>
  265. <para>
  266. Eine komplette Liste dieser Parameter ist im <ulink
  267. url="http://code.google.com/apis/base/items-feed.html#QueParameters">Abfrage
  268. Parameter Kapitel</ulink> der Feed Fetzen Dokumentation vorhanden.
  269. </para>
  270. </sect4>
  271. </sect3>
  272. <sect3 id="zend.gdata.gbase.retrieve.iterate">
  273. <title>Über die Elemente iterieren</title>
  274. <para>
  275. Google Base Elemente können Element-Spezifische Attribute enthalten, wie
  276. <code>&lt;g:main_ingredient&gt;</code> und <code>&lt;g:weight&gt;</code>.
  277. </para>
  278. <para>
  279. Um über alle Attribute eines gegebenen Elements zu iterieren, gibt es die
  280. <code>getGbaseAttributes()</code> Methode die über alle Ergebnisse iteriert:
  281. </para>
  282. <programlisting language="php"><![CDATA[
  283. foreach ($feed->entries as $entry) {
  284. // Alle Attribute erhalten und den Namen und den Textwert
  285. // jedes Attributes ausgeben
  286. $baseAttributes = $entry->getGbaseAttributes();
  287. foreach ($baseAttributes as $attr) {
  288. echo "Attribut " . $attr->name . " : " . $attr->text . "<br>";
  289. }
  290. }
  291. ]]></programlisting>
  292. <para>
  293. Oder es kann auf spezielle Attributnamen gesehen werden und über die passenden
  294. Ergebnisse iteriert werden:
  295. </para>
  296. <programlisting language="php"><![CDATA[
  297. foreach ($feed->entries as $entry) {
  298. // Gibt alle Hauptzutaten aus <g:main_ingredient>
  299. $baseAttributes = $entry->getGbaseAttribute("main_ingredient");
  300. foreach ($baseAttributes as $attr) {
  301. echo "Hauptzutaten: " . $attr->text . "<br>";
  302. }
  303. }
  304. ]]></programlisting>
  305. </sect3>
  306. </sect2>
  307. <sect2 id="zend.gdata.gbase.crud">
  308. <title>Benutzerdefinierte Elemente einfügen, aktualisieren und löschen</title>
  309. <para>
  310. Ein Benutzer/Eigentümer kann auf seine eigenen Benutzerdefinierten Feed Elemente
  311. zugreifen um Sie hinzuzufügen, zu aktualisieren oder Ihre Elemente zu löschen. Diese
  312. Operationen sind für den öffentlichen Feed Fetzen nicht vorhanden.
  313. </para>
  314. <para>
  315. Eine Feed Operation kann getestet werden bevor diese wirklich ausgeführt wird durch das
  316. setzen des Dry-Run Flags (<code>$dryRun</code>) auf <constant>TRUE</constant>. Sobald
  317. sichergestellt ist das die Daten übertragen werden sollen, muß es auf <constant>FALSE</constant>
  318. gesetzt werden um die Operation durchzuführen.
  319. </para>
  320. <sect3 id="zend.gdata.gbase.crud.insert">
  321. <title>Ein Element einfügen</title>
  322. <para>
  323. Elemente können hinzugefügt werden durch Verwenden der
  324. <code>insertGbaseItem()</code> Methode des Base Services:
  325. </para>
  326. <programlisting language="php"><![CDATA[
  327. $service = new Zend_Gdata_Gbase($client);
  328. $newEntry = $service->newItemEntry();
  329. // Überschrift hinzufügen
  330. $title = "PHP Entwickler Handbuch";
  331. $newEntry->title = $service->newTitle(trim($title));
  332. // Etwas Inhalt hinzufügen
  333. $content = "Wichtiges Handbuch für PHP Entwickler.";
  334. $newEntry->content = $service->newContent($content);
  335. $newEntry->content->type = 'text';
  336. // Produkt Typ definieren
  337. $itemType = "Produkte";
  338. $newEntry->itemType = $itemType;
  339. // Ein spezielles Element Attribut hinzufügen
  340. $newEntry->addGbaseAttribute("product_type", "book", "text");
  341. $newEntry->addGbaseAttribute("price", "12.99 USD", "floatUnit");
  342. $newEntry->addGbaseAttribute("quantity", "10", "int");
  343. $newEntry->addGbaseAttribute("weight", "2.2 lbs", "numberUnit");
  344. $newEntry->addGbaseAttribute("condition", "New", "text");
  345. $newEntry->addGbaseAttribute("author", "John Doe", "text");
  346. $newEntry->addGbaseAttribute("edition", "First Edition", "text");
  347. $newEntry->addGbaseAttribute("pages", "253", "number");
  348. $newEntry->addGbaseAttribute("publisher", "My Press", "text");
  349. $newEntry->addGbaseAttribute("year", "2007", "number");
  350. $newEntry->addGbaseAttribute("payment_accepted", "Google Checkout", "text");
  351. $dryRun = true;
  352. $createdEntry = $service->insertGbaseItem($newEntry, $dryRun);
  353. ]]></programlisting>
  354. </sect3>
  355. <sect3 id="zend.gdata.gbase.crud.modify">
  356. <title>Ein Element modifizieren</title>
  357. <para>
  358. Jedes Atribut eines Element kann aktualisiert werden wenn durch Sie iteriert wird:
  359. </para>
  360. <programlisting language="php"><![CDATA[
  361. // Die Überschrift aktualisieren
  362. $newTitle = "PHP Entwickler Handbuch zweite Editiondbook Second Edition";
  363. $entry->title = $service->newTitle($newTitle);
  364. // <g:price> Attribute finden und den Preis aktualisieren
  365. $baseAttributes = $entry->getGbaseAttribute("price");
  366. if (is_object($baseAttributes[0])) {
  367. $newPrice = "16.99 USD";
  368. $baseAttributes[0]->text = $newPrice;
  369. }
  370. // <g:pages> Attribute finden und die anzahl an Seiten aktualisieren
  371. $baseAttributes = $entry->getGbaseAttribute("pages");
  372. if (is_object($baseAttributes[0])) {
  373. $newPages = "278";
  374. $baseAttributes[0]->text = $newPages;
  375. // Den Attribut Typ von "number" zu "int" aktualisieren
  376. if ($baseAttributes[0]->type == "number") {
  377. $newType = "int";
  378. $baseAttributes[0]->type = $newType;
  379. }
  380. }
  381. // <g:label> Attribute entfernen
  382. $baseAttributes = $entry->getGbaseAttribute("label");
  383. foreach ($baseAttributes as $note) {
  384. $entry->removeGbaseAttribute($note);
  385. }
  386. // Neue Attribute hinzufügen
  387. $entry->addGbaseAttribute("note", "PHP 5", "text");
  388. $entry->addGbaseAttribute("note", "Web Programming", "text");
  389. // Die Änderungen abspeichern durch Aufruf von save() am Element-Objekt selbst
  390. $dryRun = true;
  391. $entry->save($dryRun);
  392. // Oder die Änderungen durch Aufruf von updateGbaseItem() am Service Objekt abspeichern
  393. // $dryRun = true;
  394. // $service->updateGbaseItem($entry, $dryRun);
  395. ]]></programlisting>
  396. <para>
  397. Nach der Durchführung der Änderungen, muß entweder die <code>save($dryRun)</code>
  398. Methode am <classname>Zend_Gdata_Gbase_ItemEntry</classname> Objekt oder die
  399. <code>updateGbaseItem($entry, $dryRun)</code> Methode am
  400. <classname>Zend_Gdata_Gbase</classname> Objekt aufgerufen werden um die Änderungen
  401. abzuspeichern.
  402. </para>
  403. </sect3>
  404. <sect3 id="zend.gdata.gbase.crud.delete">
  405. <title>Ein Element löschen</title>
  406. <para>
  407. ein Element kann gelöscht werden indem die <code>deleteGbaseItem()</code> Methode
  408. aufgerufen wird:
  409. </para>
  410. <programlisting language="php"><![CDATA[
  411. $dryRun = false;
  412. $service->deleteGbaseItem($entry, $dryRun);
  413. ]]></programlisting>
  414. <para>
  415. Alternativ kann <code>delete()</code> auf dem
  416. <classname>Zend_Gdata_Gbase_ItemEntry</classname> Objekt aufgerufen werden:
  417. </para>
  418. <programlisting language="php"><![CDATA[
  419. $dryRun = false;
  420. $entry->delete($dryRun);
  421. ]]></programlisting>
  422. </sect3>
  423. </sect2>
  424. </sect1>