Zend_Gdata_Gbase.xml 21 KB

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