Zend_Gdata_Gapps.xml 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15156 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.gdata.gapps">
  5. <title>Google Apps Provisionierung verwenden</title>
  6. <para>
  7. Google Apps ist ein Service der es Domain Administratoren erlaubt Ihren Benutzern einen gemanagten
  8. Zugriff auf Google Services wie Mail, Kalender und Dokumente &amp; Tabellenkalkulationen zu bieten.
  9. Die Provisionierungs API bietet ein programmmäßiges Interface um dieses Service zu konfigurieren.
  10. Im speziellen erlaubt es diese API den Administratoren Benutzerzugänge, Nicknamen und Email Listen
  11. zu erstellen, zu empfangen, zu verändern und zu löschen.
  12. </para>
  13. <para>
  14. Diese Bibliothek implementiert die Version 2.0 der Provisionierungs API. Zugriff zum eigenen Konto über
  15. die Provisionierungs API muß manuell für jede Domain aktiviert werden die das Google Apps Kontrollpanel
  16. verwendet. Nur bestimmte Kontotpen sind fähig dieses Feature einzuschalten.
  17. </para>
  18. <para>
  19. Für weitere Information zur Google Apps Provisionierungs API, inklusive Anleitungen für das einschalten
  20. des API Zugriffs, kann in die
  21. <ulink url="http://code.google.com/apis/calendar/overview.html">Provisionierungs API V2.0 Referenz</ulink>
  22. gesehen werden.
  23. </para>
  24. <note>
  25. <title>Authentifizierung</title>
  26. <para>
  27. Die Provisionierungs API unterstützt keine Authentifizierung über AuthSub und anonymer Zugriff ist
  28. nicht gestattet. Alle HTTP Verbindungen müssen mit Hilfe der ClientAuth Authentifizierung
  29. authentifiziert werden.
  30. </para>
  31. </note>
  32. <sect2 id="zend.gdata.gapps.domain">
  33. <title>Die aktuelle Domain setzen</title>
  34. <para>
  35. Um die Provisionierungs API zu verwenden muß die Domain, die administriert werden soll, in allen
  36. Anfrage URIs spezifiziert werden. Um die Entwicklung zu vereinfachen, wird diese Information sowohl
  37. im Gapps Service und den Abfrageklassen gespeichert um Sie zu verwenden wenn Abfragen erstellt werden.
  38. </para>
  39. <sect3 id="zend.gdata.gapps.domain.service">
  40. <title>Setzen der Domain für die Serviceklasse</title>
  41. <para>
  42. Um die Domain für die von der Serviceklasse durchgeführten Anfragen zu setzen kann entweder
  43. <code>setDomain()</code> aufgerufen oder die Domain bei der Instanzierung der Serviceklasse
  44. spezifiziert werden. Zum Beispiel:
  45. </para>
  46. <programlisting role="php"><![CDATA[
  47. $domain = "example.com";
  48. $gdata = new Zend_Gdata_Gapps($client, $domain);
  49. ]]></programlisting>
  50. </sect3>
  51. <sect3 id="zend.gdata.gapps.domain.query">
  52. <title>Die Domain für die Abfrageklasse setzen</title>
  53. <para>
  54. Das Setzen der Domain für Anfrage die durch die Abfrageklasse durchgeführt werden ist ähnlich dem
  55. setzen für die Serviceklasse-entweder wird <code>setDomain()</code> aufgerufen, oder die Domain
  56. wird bei der Erstellung der Abfrage angegeben. Zum Beispiel:
  57. </para>
  58. <programlisting role="php"><![CDATA[
  59. $domain = "example.com";
  60. $query = new Zend_Gdata_Gapps_UserQuery($domain, $arg);
  61. ]]></programlisting>
  62. <para>
  63. Wenn eine Serviceklassen Factorymethode verwendet wird um eine Abfrage zu erstellen, setzt
  64. die Serviceklasse die Domain der Abfrage automatisch so das Sie ihrer eigenen Domain entspricht.
  65. Als Ergebnis ist es nicht notwendig die Domain als Teil der Konstruktorargumente zu spezifizieren.
  66. </para>
  67. <programlisting role="php"><![CDATA[
  68. $domain = "example.com";
  69. $gdata = new Zend_Gdata_Gapps($client, $domain);
  70. $query = $gdata->newUserQuery($arg);
  71. ]]></programlisting>
  72. </sect3>
  73. </sect2>
  74. <sect2 id="zend.gdata.gapps.users">
  75. <title>Interaktion mit Benutzern</title>
  76. <para>
  77. Jeder Benutzerzugang zu einer Google Apps gehosteten Domain wird als Instanz von
  78. <classname>Zend_Gdata_Gapps_UserEntry</classname> repräsentiert. Diese Klasse bietet Zugriff zu allen Zugangseigenschaften
  79. inklusive Name, Benutzername, Passwort, Zugriffsrehte und aktuellen Quoten.
  80. </para>
  81. <sect3 id="zend.gdata.gapps.users.creating">
  82. <title>Erstellen eines Benutzerzugangs</title>
  83. <para>
  84. Benutzerzugänge können durch den Aufruf der einfachen <code>createUser()</code> Methode erstellt
  85. werden:
  86. </para>
  87. <programlisting role="php"><![CDATA[
  88. $gdata->createUser('foo', 'Random', 'User', '••••••••');
  89. ]]></programlisting>
  90. <para>
  91. Benutzer können durch das instanzieren eines UserEntry erstellt werden, indem ein Benutzername,
  92. ein Name, ein Familienname und ein Passwort angegeben werden und anschließend
  93. <code>insertUser()</code> am Serviceobjekt aufgerufen wird um den Eintrag zum Server zu laden.
  94. </para>
  95. <programlisting role="php"><![CDATA[
  96. $user = $gdata->newUserEntry();
  97. $user->login = $gdata->newLogin();
  98. $user->login->username = 'foo';
  99. $user->login->password = '••••••••';
  100. $user->name = $gdata->newName();
  101. $user->name->givenName = 'Irgendwer';
  102. $user->name->familyName = 'Benutzer';
  103. $user = $gdata->insertUser($user);
  104. ]]></programlisting>
  105. <para>
  106. Das Passwort den Benutzers sollte normalerweise als Klartext angegeben werden. Operional kann
  107. das Passwort als SHA-1 Schlüssel angegeben werden wenn <code>login->passwordHashFunction</code>
  108. auf 'SHA-1' gesetzt ist.
  109. </para>
  110. </sect3>
  111. <sect3 id="zend.gdata.gapps.users.retrieving">
  112. <title>Einen Benutzerzugang erhalten</title>
  113. <para>
  114. Individuelle Benutzerzugänge kann man erhalten indem die einfache <code>retrieveUser()</code>
  115. Methode aufgerufen wird. Wenn der Benutzer nicht gefunden wird, wird <code>null</code>
  116. zurückgegeben.
  117. </para>
  118. <programlisting role="php"><![CDATA[
  119. $user = $gdata->retrieveUser('foo');
  120. echo 'Benutzername: ' . $user->login->userName . "\n";
  121. echo 'Name: ' . $user->login->givenName . "\n";
  122. echo 'Familienname: ' . $user->login->familyName . "\n";
  123. echo 'Unterbrochen: ' . ($user->login->suspended ? 'Ja' : 'Nein') . "\n";
  124. echo 'Administrator: ' . ($user->login->admin ? 'Ja' : 'Nein') . "\n"
  125. echo 'Muss das Passwort ändern: ' .
  126. ($user->login->changePasswordAtNextLogin ? 'Ja' : 'Nein') . "\n";
  127. echo 'Hat den Regeln zugestimmt: ' .
  128. ($user->login->agreedToTerms ? 'Ja' : 'Nein') . "\n";
  129. ]]></programlisting>
  130. <para>
  131. Benutzer kann man auch erhalten indem eine Instanz von <classname>Zend_Gdata_Gapps_UserQuery</classname> erstellt wird,
  132. und dessen username Eigenschaft dem Benutzernamen des Benutzers entspricht den man erhalten will
  133. und <code>getUserEntry()</code> auf einem Serviceobjekt mit dieser Abfrage aufruft.
  134. </para>
  135. <programlisting role="php"><![CDATA[
  136. $query = $gdata->newUserQuery('foo');
  137. $user = $gdata->getUserEntry($query);
  138. echo 'Benutzername: ' . $user->login->userName . "\n";
  139. echo 'Name: ' . $user->login->givenName . "\n";
  140. echo 'Familien Name: ' . $user->login->familyName . "\n";
  141. echo 'Unterbrochen: ' . ($user->login->suspended ? 'Ja' : 'Nein') . "\n";
  142. echo 'Administrator: ' . ($user->login->admin ? 'Ja' : 'Nein') . "\n"
  143. echo 'Muss das Passwort ändern: ' .
  144. ($user->login->changePasswordAtNextLogin ? 'Ja' : 'Nein') . "\n";
  145. echo 'Hat den Regeln zugestimmt: ' .
  146. ($user->login->agreedToTerms ? 'Ja' : 'Nein') . "\n";
  147. ]]></programlisting>
  148. <para>
  149. Wenn der spezifizierte Benutzer nicht gefunden werden kann wird eine ServiceException mit einem
  150. Fehlercode von <classname>Zend_Gdata_Gapps_Error::ENTITY_DOES_NOT_EXIST</classname> geworfen. ServiceExceptions werden
  151. in <xref linkend="zend.gdata.gapps.exceptions" /> behandelt.
  152. </para>
  153. </sect3>
  154. <sect3 id="zend.gdata.gapps.users.retrievingAll">
  155. <title>Alle Benutzer in einer Domain erhalten</title>
  156. <para>
  157. Um alle Benutzer in einer Domäne zu erhalten kann die einfache <code>retrieveAllUsers()</code>
  158. Methode aufgerufen werden.
  159. </para>
  160. <programlisting role="php"><![CDATA[
  161. $feed = $gdata->retrieveAllUsers();
  162. foreach ($feed as $user) {
  163. echo " * " . $user->login->username . ' (' . $user->name->givenName .
  164. ' ' . $user->name->familyName . ")\n";
  165. }
  166. ]]></programlisting>
  167. <para>
  168. Das wird ein <classname>Zend_Gdata_Gapps_UserFeed</classname> Objekt erstellen welches jeden Benutzer dieser Domain
  169. enthält.
  170. </para>
  171. <para>
  172. Alternativ kann <code>getUserFeed()</code> ohne Optionen aufgerufen werden. Es ist zu beachten
  173. das dieser Feed bei größeren Domains durch den Server in Seiten ausgegeben werden kann. Über
  174. weitere Informationen der Ausgabe in Seiten siehe
  175. <xref linkend="zend.gdata.introduction.paging" />.
  176. </para>
  177. <programlisting role="php"><![CDATA[
  178. $feed = $gdata->getUserFeed();
  179. foreach ($feed as $user) {
  180. echo " * " . $user->login->username . ' (' . $user->name->givenName .
  181. ' ' . $user->name->familyName . ")\n";
  182. }
  183. ]]></programlisting>
  184. </sect3>
  185. <sect3 id="zend.gdata.gapps.users.updating">
  186. <title>Einen Benutzerzugang aktualisieren</title>
  187. <para>
  188. Der einfachste Weg um einen Benutzerzugang zu aktualisieren ist es den Benutzer wie in der
  189. vorherigen Sektion beschrieben zu empfangen, jegliche gewünschte Änderungen durchzuführen und
  190. anschließend <code>save()</code> auf diesem Benutzer aufzurufen. Jede gemachte Änderung wird
  191. an den Server weitergegeben.
  192. </para>
  193. <programlisting role="php"><![CDATA[
  194. $user = $gdata->retrieveUser('foo');
  195. $user->name->givenName = 'Foo';
  196. $user->name->familyName = 'Bar';
  197. $user = $user->save();
  198. ]]></programlisting>
  199. <sect4 id="zend.gdata.gapps.users.updating.resettingPassword">
  200. <title>Ein Benutzerpasswort resetieren</title>
  201. <para>
  202. Ein Benutzerpasswort kann zu einem neuen Wert resetiert werden indem die
  203. <code>login->password</code> Eigenschaft aktualisiert wird.
  204. </para>
  205. <programlisting role="php"><![CDATA[
  206. $user = $gdata->retrieveUser('foo');
  207. $user->login->password = '••••••••';
  208. $user = $user->save();
  209. ]]></programlisting>
  210. <para>
  211. Es ist zu beachten das es nicht möglich ist ein Passwort auf diesem Weg wiederherzustellen da
  212. gespeicherte Passwörter aus Sicherheitsgründern nicht über die Provisionierungs API
  213. verfügbar gemacht werden.
  214. </para>
  215. </sect4>
  216. <sect4 id="zend.gdata.gapps.users.updating.forcingPasswordChange">
  217. <title>Einen Benutzer zwingen sein Passwort zu ändern</title>
  218. <para>
  219. Ein Benutzer kann dazu gezwungen werden sein Passwort bei seinem nächsten Login zu ändern,
  220. indem die <code>login->changePasswordAtNextLogin</code> Eigenschaft auf <code>true</code>
  221. gesetzt wird.
  222. </para>
  223. <programlisting role="php"><![CDATA[
  224. $user = $gdata->retrieveUser('foo');
  225. $user->login->changePasswordAtNextLogin = true;
  226. $user = $user->save();
  227. ]]></programlisting>
  228. <para>
  229. Genauso kann das rückgängig gemacht werden indem die
  230. <code>login->changePasswordAtNextLogin</code> Eigenschaft auf <code>false</code> gesetzt wird.
  231. </para>
  232. </sect4>
  233. <sect4 id="zend.gdata.gapps.users.updating.suspendingAccount">
  234. <title>Einen Benutzerzugang unterbrechen</title>
  235. <para>
  236. Benutzer können daran gehindert werden sich anzumelden ohne das Ihr Benutzerzugang
  237. gelöscht wird indem Ihr Benutzerzugang <emphasis>unterbrochen</emphasis> wird. Zugänge
  238. können unterbrochen oder wiederhergestellt werden indem die einfachen
  239. <code>suspendUser()</code> und <code>restoreUser()</code> Methoden verwendet werden:
  240. </para>
  241. <programlisting role="php"><![CDATA[
  242. $gdata->suspendUser('foo');
  243. $gdata->restoreUser('foo');
  244. ]]></programlisting>
  245. <para>
  246. Alternativ kann die Eigenschaft <code>login->suspended</code> des Benutzerzugangs auf
  247. <code>true</code> gesetzt werden.
  248. </para>
  249. <programlisting role="php"><![CDATA[
  250. $user = $gdata->retrieveUser('foo');
  251. $user->login->suspended = true;
  252. $user = $user->save();
  253. ]]></programlisting>
  254. <para>
  255. Um den Benutzerzugang wiederherzustellen muß die <code>login->suspended</code> Eigenschaft
  256. auf <code>false</code> gesetzt werden.
  257. </para>
  258. </sect4>
  259. <sect4 id="zend.gdata.gapps.users.updating.grantingAdminRights">
  260. <title>Administrative Rechte vergeben</title>
  261. <para>
  262. Benutzern kann die Möglichkeit gegeben werden die Domain zu verwalten durch das setzen
  263. Ihrer <code>login->admin</code> Eigenschaft auf <code>true</code>.
  264. </para>
  265. <programlisting role="php"><![CDATA[
  266. $user = $gdata->retrieveUser('foo');
  267. $user->login->admin = true;
  268. $user = $user->save();
  269. ]]></programlisting>
  270. <para>
  271. Und wie erwartet, entfernt das Setzen der Eigenschaft <code>login->admin</code>, des
  272. Benutzers auf <code>false</code>, dessen administrative Rechte.
  273. </para>
  274. </sect4>
  275. </sect3>
  276. <sect3 id="zend.gdata.gapps.users.deleting">
  277. <title>Löschen eines Benutzerzugangs</title>
  278. <para>
  279. Einen Benutzerzugang zu löschen zu dem man bereits ein UserEntry hat, ist so einfach wie der
  280. Aufruf von <code>delete()</code> auf diesem Eintrag.
  281. </para>
  282. <programlisting role="php"><![CDATA[
  283. $user = $gdata->retrieveUser('foo');
  284. $user->delete();
  285. ]]></programlisting>
  286. <para>
  287. Wenn man keinen Zugriff auf ein UserEntry Objekt für einen Zugang hat, kann die einfache
  288. <code>deleteUser()</code> Methode verwendet werden.
  289. </para>
  290. <programlisting role="php"><![CDATA[
  291. $gdata->deleteUser('foo');
  292. ]]></programlisting>
  293. </sect3>
  294. </sect2>
  295. <sect2 id="zend.gdata.gapps.nicknames">
  296. <title>Mit Spitznamen interagieren</title>
  297. <para>
  298. Spitznamen arbeiten als Email Aliase für bestehende Benutzer. Jeder Spitzname enthält genau zwei
  299. Schlüsseleigenschaften: Seinen Namen und seinen Eigentümer. Jede Email die zu einem Spitznamen
  300. adressiert wurde wird zu dem Benutzer weitergeleitet der diesen Spitznamen besitzt.
  301. </para>
  302. <para>
  303. Spitznamen werden repräsentiert als Instanz von <classname>Zend_Gdata_Gapps_NicknameEntry</classname>.
  304. </para>
  305. <sect3 id="zend.gdata.gapps.nicknames.creating">
  306. <title>Erstellen eines Spitznamens</title>
  307. <para>
  308. Spitznamen können durch den Aufruf der einfachen <code>createNickname()</code> Methode
  309. erstellt werden:
  310. </para>
  311. <programlisting role="php"><![CDATA[
  312. $gdata->createNickname('foo', 'bar');
  313. ]]></programlisting>
  314. <para>
  315. Spitznamen können auch durch das instanzieren eines NichnameEntry erstellt werden, wobei der
  316. Spitzname mit einem Namen und einem Eigentümer ausgestattet wird, und dann
  317. <code>insertNickname()</code> auf einem Service Objekt aufgerufen wird, um den Eintrag zu einem
  318. Server hochzuladen.
  319. </para>
  320. <programlisting role="php"><![CDATA[
  321. $nickname = $gdata->newNicknameEntry();
  322. $nickname->login = $gdata->newLogin('foo');
  323. $nickname->nickname = $gdata->newNickname('bar');
  324. $nickname = $gdata->insertNickname($nickname);
  325. ]]></programlisting>
  326. </sect3>
  327. <sect3 id="zend.gdata.gapps.nicknames.retrieving">
  328. <title>Einen Spitznamen empfangen</title>
  329. <para>
  330. Spitznamen können durch den Aufruf der bequemen <code>retrieveNickname()</code> Methode
  331. empfangen werden. Sie gibt <code>null</code> zurück wenn der Benutzer nicht gefunden wurde.
  332. </para>
  333. <programlisting role="php"><![CDATA[
  334. $nickname = $gdata->retrieveNickname('bar');
  335. echo 'Spitzname: ' . $nickname->nickname->name . "\n";
  336. echo 'Eigentümer: ' . $nickname->login->username . "\n";
  337. ]]></programlisting>
  338. <para>
  339. Individuelle Spitznamen können durch Erstellung einer <classname>Zend_Gdata_Gapps_NicknameQuery</classname> Instanz
  340. erhalten werden, indem dessen nickname Eigenschaft dem Spitznamen gleichgesetzt wird der
  341. empfangen werden soll, und <code>getNicknameEntry()</code> auf einem Server Objekt mit dieser
  342. Abfrage aufgerufen wird.
  343. </para>
  344. <programlisting role="php"><![CDATA[
  345. $query = $gdata->newNicknameQuery('bar');
  346. $nickname = $gdata->getNicknameEntry($query);
  347. echo 'Spitzname: ' . $nickname->nickname->name . "\n";
  348. echo 'Eigentümer: ' . $nickname->login->username . "\n";
  349. ]]></programlisting>
  350. <para>
  351. Genau wie bei den Benutzern wird eine ServiceException geworfen wenn kein entsprechender
  352. Spitzname gefunden wurde und ein Fehlercode von <classname>Zend_Gdata_Gapps_Error::ENTITY_DOES_NOT_EXIST</classname>
  353. zurückgegeben. Auch das wird in <xref linkend="zend.gdata.gapps.exceptions" /> beschrieben.
  354. </para>
  355. </sect3>
  356. <sect3 id="zend.gdata.gapps.nicknames.retrievingUser">
  357. <title>Alle Spitznamen eines Benutzers erhalten</title>
  358. <para>
  359. Um alle Spitznamen zu erhalten die einem angegebenen Benutzer assoziiert sind, kann die
  360. bequeme <code>retrieveNicknames()</code> Methode aufgerufen werden.
  361. </para>
  362. <programlisting role="php"><![CDATA[
  363. $feed = $gdata->retrieveNicknames('foo');
  364. foreach ($feed as $nickname) {
  365. echo ' * ' . $nickname->nickname->name . "\n";
  366. }
  367. ]]></programlisting>
  368. <para>
  369. Das erzeugt ein <classname>Zend_Gdata_Gapps_NicknameFeed</classname> Objekt welches jeden mit dem spezifizierten
  370. Benutzer assoziierten Spitznamen enthält.
  371. </para>
  372. <para>
  373. Alternativ setzt das Erstellen einer neuen <classname>Zend_Gdata_Gapps_NicknameQuery</classname> dessen username
  374. Eigenschaft auf den gewünschten Benutzer, und überträgt die Abfrage durch den Aufruf von
  375. <code>getNicknameFeed()</code> auf dem Service Objekt.
  376. </para>
  377. <programlisting role="php"><![CDATA[
  378. $query = $gdata->newNicknameQuery();
  379. $query->setUsername('foo');
  380. $feed = $gdata->getNicknameFeed($query);
  381. foreach ($feed as $nickname) {
  382. echo ' * ' . $nickname->nickname->name . "\n";
  383. }
  384. ]]></programlisting>
  385. </sect3>
  386. <sect3 id="zend.gdata.gapps.nicknames.retrievingAll">
  387. <title>Empfangen aller Spitznamen in einer Domain</title>
  388. <para>
  389. Um alle Spitznamen in einerm Feed zu empfangen, muß einfach die bequeme Methode
  390. <code>retrieveAllNicknames()</code> aufgerufen werden.
  391. </para>
  392. <programlisting role="php"><![CDATA[
  393. $feed = $gdata->retrieveAllNicknames();
  394. foreach ($feed as $nickname) {
  395. echo ' * ' . $nickname->nickname->name . ' => ' .
  396. $nickname->login->username . "\n";
  397. }
  398. ]]></programlisting>
  399. <para>
  400. Das wird ein <classname>Zend_Gdata_Gapps_NicknameFeed</classname> Objekt erstellen welches jeden Spitznamen in der
  401. Domain enthält.
  402. </para>
  403. <para>
  404. Alternativ kann <code>getNicknameFeed()</code> auf einem Service Objekt ohne Argumente aufgerufen
  405. werden.
  406. </para>
  407. <programlisting role="php"><![CDATA[
  408. $feed = $gdata->getNicknameFeed();
  409. foreach ($feed as $nickname) {
  410. echo ' * ' . $nickname->nickname->name . ' => ' .
  411. $nickname->login->username . "\n";
  412. }
  413. ]]></programlisting>
  414. </sect3>
  415. <sect3 id="zend.gdata.gapps.nicknames.deleting">
  416. <title>Löschen eines Spitznamens</title>
  417. <para>
  418. Um einen Spitznamen zu löschen zu dem man bereits einen NicknameEntry hält muß einfach nur
  419. <code>delete()</code> auf diesem Eintrag aufgerufen werden.
  420. </para>
  421. <programlisting role="php"><![CDATA[
  422. $nickname = $gdata->retrieveNickname('bar');
  423. $nickname->delete();
  424. ]]></programlisting>
  425. <para>
  426. Für Spitznamen zu denen man keinen NicknameEntry hält, kann die bequeme
  427. <code>deleteNickname()</code> Methode verwendet werden.
  428. </para>
  429. <programlisting role="php"><![CDATA[
  430. $gdata->deleteNickname('bar');
  431. ]]></programlisting>
  432. </sect3>
  433. </sect2>
  434. <sect2 id="zend.gdata.gapps.emailLists">
  435. <title>Mit Email Listen interagieren</title>
  436. <para>
  437. Email Listen erlauben verschiedenen Benutzern Emails zu empfangen die zu einer einzelnen Email
  438. Adresse adressiert sind. Benutzer müssen keine Teilnehmer dieser Domain sein um sich in eine
  439. Email Liste einzuschreiben, wen deren komplette Email Adresse (inklusive Domain) verwendet wird.
  440. </para>
  441. <para>
  442. Jede Email Liste einer Domain wird als Instanz von <classname>Zend_Gdata_Gapps_EmailListEntry</classname> repräsentiert.
  443. </para>
  444. <sect3 id="zend.gdata.gapps.emailLists.creating">
  445. <title>Erstellen einer Email Liste</title>
  446. <para>
  447. Email Listen können durch den Aufruf der bequemen <code>createEmailList()</code> Methode
  448. erstellt werden:
  449. </para>
  450. <programlisting role="php"><![CDATA[
  451. $gdata->createEmailList('friends');
  452. ]]></programlisting>
  453. <para>
  454. Email Listen können auch durch die Instanzierung von EmailListEntry erstellt werden, indem
  455. ein Name für die Liste angegeben wird, und anschließend <code>insertEmailList()</code> auf
  456. dem Service Objekt aufgerufen wird um den Eintrag zum Server hochzuladen.
  457. </para>
  458. <programlisting role="php"><![CDATA[
  459. $list = $gdata->newEmailListEntry();
  460. $list->emailList = $gdata->newEmailList('friends');
  461. $list = $gdata->insertEmailList($list);
  462. ]]></programlisting>
  463. </sect3>
  464. <sect3 id="zend.gdata.gapps.emailList.retrieve">
  465. <title>Empfangen aller Email Listen bei denen ein Empfänger eingeschrieben ist</title>
  466. <para>
  467. Um alle Email Lsiten zu denen ein spezieller Empfänger eingeschrieben ist zu empfangen, muß die
  468. bequeme <code>retrieveEmailLists()</code> Methode aufgerufen werden:
  469. </para>
  470. <programlisting role="php"><![CDATA[
  471. $feed = $gdata->retrieveEmailLists('baz@somewhere.com');
  472. foreach ($feed as $list) {
  473. echo ' * ' . $list->emailList->name . "\n";
  474. }
  475. ]]></programlisting>
  476. <para>
  477. Das erstellt ein <classname>Zend_Gdata_Gapps_EmailListFeed</classname> Objekt welches jede Email Liste enthält die
  478. mit dem speziellen Empfänger assoziiert ist.
  479. </para>
  480. <para>
  481. Alternativ kann ein neues <classname>Zend_Gdata_Gapps_EmailListQuery</classname> erstellt werden, dessen recipient
  482. Eigenschaft auf die gewünschte Email Adresse gesetzt werden, und die Abfrage durch den Aufruf
  483. von <code>getEmailListFeed()</code> auf dem Service Objekt übermittelt werden.
  484. </para>
  485. <programlisting role="php"><![CDATA[
  486. $query = $gdata->newEmailListQuery();
  487. $query->setRecipient('baz@somewhere.com');
  488. $feed = $gdata->getEmailListFeed($query);
  489. foreach ($feed as $list) {
  490. echo ' * ' . $list->emailList->name . "\n";
  491. }
  492. ]]></programlisting>
  493. </sect3>
  494. <sect3 id="zend.gdata.gapps.emailLists.retrievingAll">
  495. <title>Empfangen aller Email Listen in einer Domain</title>
  496. <para>
  497. Um alle Email Listen in einer Domain zu erhalten, muß die bequeme
  498. <code>retrieveAllEmailLists()</code> Methode aufgerufen werden.
  499. </para>
  500. <programlisting role="php"><![CDATA[
  501. $feed = $gdata->retrieveAllEmailLists();
  502. foreach ($feed as $list) {
  503. echo ' * ' . $list->emailList->name . "\n";
  504. }
  505. ]]></programlisting>
  506. <para>
  507. Das erzeugt ein <classname>Zend_Gdata_Gapps_EmailListFeed</classname> Objekt welches jede Email Liste der Domain
  508. enthält.
  509. </para>
  510. <para>
  511. Alternativ kann <code>getEmailListFeed()</code> auf dem Service Objekt ohne Argumente aufgerufen
  512. werden.
  513. </para>
  514. <programlisting role="php"><![CDATA[
  515. $feed = $gdata->getEmailListFeed();
  516. foreach ($feed as $list) {
  517. echo ' * ' . $list->emailList->name . "\n";
  518. }
  519. ]]></programlisting>
  520. </sect3>
  521. <sect3 id="zend.gdata.gapps.emailList.deleting">
  522. <title>Löschen einer Email Liste</title>
  523. <para>
  524. Um eine Email Liste zu löschen, muß die bequeme deleteEmailList() Methode aufgerufen werden:
  525. </para>
  526. <programlisting role="php"><![CDATA[
  527. $gdata->deleteEmailList('friends');
  528. ]]></programlisting>
  529. </sect3>
  530. </sect2>
  531. <sect2 id="zend.gdata.gapps.emailListRecipients">
  532. <title>Mit den Empfängern von Email Listen interagieren</title>
  533. <para>
  534. Jeder Empfänger der bei einer Email Liste eingeschrieben ist, wird durch eine Instanz von
  535. <classname>Zend_Gdata_Gapps_EmailListRecipient</classname> repräsentiert. Durch diese Klasse können individuelle
  536. Empfänger hinzugefügt und von Email Listen entfernt werden.
  537. </para>
  538. <sect3 id="zend.gdata.gapps.emailListRecipients.adding">
  539. <title>Einen Empfängern zu einer Email Liste hinzufügen</title>
  540. <para>
  541. Um einen Empfänger zu einer Email Liste hinzuzufügen, muß einfach die bequeme
  542. <code>addRecipientToEmailList()</code> Methode aufgerufen werden:
  543. </para>
  544. <programlisting role="php"><![CDATA[
  545. $gdata->addRecipientToEmailList('bar@somewhere.com', 'friends');
  546. ]]></programlisting>
  547. </sect3>
  548. <sect3 id="zend.gdata.gapps.emailListRecipients.retrieving">
  549. <title>Eine Liste von Empfängern einer Email Liste erhalten</title>
  550. <para>
  551. Die bequeme <code>retrieveAllRecipients()</code> Methode kann verwendet werden um die Liste
  552. der Empfänger einer Email Liste zu erhalten:
  553. </para>
  554. <programlisting role="php"><![CDATA[
  555. $feed = $gdata->retrieveAllRecipients('friends');
  556. foreach ($feed as $recipient) {
  557. echo ' * ' . $recipient->who->email . "\n";
  558. }
  559. ]]></programlisting>
  560. <para>
  561. Alternativ kann ein neuer EmailListRecipientQuery erstellt werdne, dessen emailListName
  562. Eigenschaft auf die gewünschte Email Liste gesetzt werden, und
  563. <code>getEmailListRecipientFeed()</code> auf dem Service Objekt aufgerufen werden.
  564. </para>
  565. <programlisting role="php"><![CDATA[
  566. $query = $gdata->newEmailListRecipientQuery();
  567. $query->setEmailListName('friends');
  568. $feed = $gdata->getEmailListRecipientFeed($query);
  569. foreach ($feed as $recipient) {
  570. echo ' * ' . $recipient->who->email . "\n";
  571. }
  572. ]]></programlisting>
  573. <para>
  574. Das Erstellt ein <classname>Zend_Gdata_Gapps_EmailListRecipientFeed</classname> Objekt welche jeden Empfänger für die
  575. ausgewählte Email Liste enthält.
  576. </para>
  577. </sect3>
  578. <sect3 id="zend.gdata.gapps.emailListRecipients.removing">
  579. <title>Einen Empfänger von einer Email Liste entfernen</title>
  580. <para>
  581. Um einen Empfänger von einer Email Liste zu entfernen, muß die bequeme
  582. <code>removeRecipientFromEmailList()</code> Methode aufgerufen werden:
  583. method:
  584. </para>
  585. <programlisting role="php"><![CDATA[
  586. $gdata->removeRecipientFromEmailList('baz@somewhere.com', 'friends');
  587. ]]></programlisting>
  588. </sect3>
  589. </sect2>
  590. <sect2 id="zend.gdata.gapps.exceptions">
  591. <title>Fehler handhaben</title>
  592. <para>
  593. Zusätzlich zur Standardsuite von Ausnahmen die von <classname>Zend_Gdata</classname> geworfen werden, können Anfragen die
  594. die Provisionierungs API verwenden auch eine <classname>Zend_Gdata_Gapps_ServiceException</classname>
  595. werfen. Diese Ausnahme zeigt das ein API spezieller Fehler aufgetreten ist welche verhindert das
  596. die Anfrage fertiggestellt werden kann.
  597. </para>
  598. <para>
  599. Jede ServiceException Instanz kann einen oder mehrere Fehler Objekte enthalten. Jedes dieser
  600. Objekte enthalten einen Fehlercode, Grund und (optional) die Eingave welche die Ausnahme
  601. getriggert hat. Eine komplette Liste von bekannten Fehlercodes wird in der Zend Framework API
  602. Dokumentation unter <classname>Zend_Gdata_Gapps_Error</classname> angeboten. Zusätzlich ist die maßgebliche
  603. Fehlerliste online unter <ulink
  604. url="http://code.google.com/apis/apps/gdata_provisioning_api_v2.0_reference.html#appendix_d">Google
  605. Apps Provisioning API V2.0 Reference: Appendix D</ulink> vorhanden.
  606. </para>
  607. <para>
  608. Wärend die komplette Liste von Fehler die empfangen wurden in ServiceException als Array vorhanden
  609. sind das man durch den Aufruf von <code>getErrors()</code> erhalten kann, ist es oft bequemer
  610. zu wissen ob ein spezieller Fehler aufgetreten ist. Für diese Fälle kann das Vorhandensein eines
  611. Fehler durch den Aufruf von <code>hasError()</code> erkannt werden.
  612. </para>
  613. <para>
  614. Das folgende Beispiel demonstriert wie erkannt werden kann ob eine angefragte Ressource nicht
  615. existiert und der Fehler korrekt behandelt werden kann:
  616. </para>
  617. <programlisting role="php"><![CDATA[
  618. function retrieveUser ($username) {
  619. $query = $gdata->newUserQuery($username);
  620. try {
  621. $user = $gdata->getUserEntry($query);
  622. } catch (Zend_Gdata_Gapps_ServiceException $e) {
  623. // Den Benutzer auf null setzen wen er nicht gefunden wurde
  624. if ($e->hasError(Zend_Gdata_Gapps_Error::ENTITY_DOES_NOT_EXIST)) {
  625. $user = null;
  626. } else {
  627. throw $e;
  628. }
  629. }
  630. return $user;
  631. }
  632. ]]></programlisting>
  633. </sect2>
  634. </sect1>