2
0

Zend_Service_Nirvanix.xml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.service.nirvanix">
  5. <title>Zend_Service_Nirvanix</title>
  6. <sect2 id="zend.service.nirvanix.introduction">
  7. <title>Einführung</title>
  8. <para>
  9. Nirvanix bietet ein Internet Media File System (IMFS), einen Internet Speicher Service
  10. der es Anwendungen erlaubt Dateien hochzuladen, zu speichern, zu organisieren und
  11. nachhaltig auf Sie zuzugreifen durch Verwendung eines Standard Web Service Interfaces.
  12. Ein IMFS ist ein verteiltes geclustertes Dateisystem, auf das über das Internet
  13. zugegriffen wird, und das für die Handhabung mit Mediendateien (Audio, Video, usw.)
  14. optimiert ist. Das Ziel eines IMFA ist es massive Skalarität zu bieten um den
  15. Problemen des Wachstums der Medienspeicher Herr zu werden, mit garantiertem Zugriff und
  16. Erreichbarkeit unabhängig von Zeit und Ort. Letztendlich, gibt eine IMFS Anwendung die
  17. Möglichkeit auf Daten sicher zuzugreifen, ohne die großen Fixkosten die mit der
  18. Beschaffung und Einrichtung von physikalischen Speicherbänken verbunden sind.
  19. </para>
  20. </sect2>
  21. <sect2 id="zend.service.nirvanix.registering">
  22. <title>Registrierung bei Nirvanix</title>
  23. <para>
  24. Bevor man mit <classname>Zend_Service_Nirvanix</classname> beginnt, muß man sich zuerst
  25. für einen Account anmelden. Bitte sehen Sie auf die
  26. <ulink url="http://www.nirvanix.com/gettingStarted.aspx">Wie man anfängt</ulink> Seite
  27. auf der Nirvanix Webseite für weitere Informationen.
  28. </para>
  29. <para>
  30. Nach der Registrierung erhält man einen Benutzernamen, ein Passwort und einen
  31. Anwendungsschlüssel. Alle drei werden benötigt um
  32. <classname>Zend_Service_Nirvanix</classname> zu verwenden.
  33. </para>
  34. </sect2>
  35. <sect2 id="zend.service.nirvanix.apiDocumentation">
  36. <title>API Dokumentation</title>
  37. <para>
  38. Der Zugriff auf Nirvanix IMFS ist durch beide, sowohl ein SOAP als auch ein schnelleres
  39. REST Service möglich. <classname>Zend_Service_Nirvanix</classname> bietet einen relativ
  40. dünnen PHP 5 Wrapper um das REST Service.
  41. </para>
  42. <para>
  43. <classname>Zend_Service_Nirvanix</classname> zielt darauf ab das Nirvanix REST Service
  44. einfacher zu verwenden aber zu verstehen das das Service selbst trotzdem noch essentiell
  45. ist um mit Nirvanix erfolgreich zu sein.
  46. </para>
  47. <para>
  48. Die <ulink url="http://developer.nirvanix.com/sitefiles/1000/API.html">Nirvanix API
  49. Dokumentation</ulink> bietet eine Übersicht sowie detailierte Informationen über die
  50. Verwendung des Services. Bitte machen Sie sich mit diesem Dokument vertraut und
  51. referieren Sie darauf wenn Sie <classname>Zend_Service_Nirvanix</classname> verwenden.
  52. </para>
  53. </sect2>
  54. <sect2 id="zend.service.nirvanix.features">
  55. <title>Features</title>
  56. <para>
  57. Nirvanix's REST Service kann mit PHP effektiv verwendet werden alleine mit Hilfe der
  58. <ulink url="http://www.php.net/simplexml">SimpleXML</ulink> Erweiterung und
  59. <classname>Zend_Http_Client</classname>. Trotzdem ist deren Verwendung auf diesem Weg
  60. irgendwie unbequem wegen der wiederholenden Operationen, wie die Übergabe des Session
  61. Tokens bei jeder Anfrage und der wiederholten Prüfung des Antwort Bodys nach
  62. Fehlercodes.
  63. </para>
  64. <para>
  65. <classname>Zend_Service_Nirvanix</classname> bietet die folgenden Funktionalitäten:
  66. <itemizedlist>
  67. <listitem>
  68. <para>
  69. Einen einzelnen Punkt für die Konfiguration der Nirvanix Authentifizierungs
  70. Daten die mit den Nirvanix Namespaces verwendet werden können.
  71. </para>
  72. </listitem>
  73. <listitem>
  74. <para>
  75. Ein Proxy Objekt das viel bequemer ist als ein HTTP Client alleine,
  76. hauptsächlich wird die Notwendigkeit entfernt die HTTP POST Anfrage manuell
  77. zu erstellen um auf das REST Service zugreifen zu können.
  78. </para>
  79. </listitem>
  80. <listitem>
  81. <para>
  82. Ein verantwortlicher Wrapper der jeden Antwortbody parst und eine Ausnahme
  83. wirft wenn ein Fehler aufgetreten ist, was die Notwendigkeit mildert
  84. widerholt den Erfolg der vielen Kommandos zu prüfen.
  85. </para>
  86. </listitem>
  87. <listitem>
  88. <para>
  89. Zusätzliche bequeme Methoden für einige oder die meisten üblichen
  90. Operationen.
  91. </para>
  92. </listitem>
  93. </itemizedlist>
  94. </para>
  95. </sect2>
  96. <sect2 id="zend.service.nirvanix.storing-your-first">
  97. <title>Der Anfang</title>
  98. <para>
  99. Sobald man in Nirvanix registriert ist, ist man bereit die ersten Datein am IMFS zu
  100. speichern. Die üblichste Operation die man am IMFS benötigt ist der Erstellung einer
  101. neuen Datei, das Herunterladen bestehender Dateien, und das Löschen einer Datei.
  102. <classname>Zend_Service_Nirvanix</classname> bietet bequeme Methoden für diese drei
  103. Operationen.
  104. </para>
  105. <programlisting language="php"><![CDATA[
  106. $auth = array('username' => 'Dein-Benutzername',
  107. 'password' => 'Dein-Passwort',
  108. 'appKey' => 'Dein-App-Schlüssel');
  109. $nirvanix = new Zend_Service_Nirvanix($auth);
  110. $imfs = $nirvanix->getService('IMFS');
  111. $imfs->putContents('/foo.txt', 'zu speichernder Inhalt');
  112. echo $imfs->getContents('/foo.txt');
  113. $imfs->unlink('/foo.txt');
  114. ]]></programlisting>
  115. <para>
  116. Der erste Schritt um <classname>Zend_Service_Nirvanix</classname> zu verwenden ist immer
  117. sich gegenüber dem Service zu authentifizieren. Das wird durch die Übergabe der
  118. Anmeldedaten an den Kontruktor von <classname>Zend_Service_Nirvanix</classname>, wie
  119. oben, gemacht. Das assoziative Array wurd direkt an Nirvanix als POST Parameter
  120. übergeben.
  121. </para>
  122. <para>
  123. Nirvanix teilt seine WebService in <ulink
  124. url="http://developer.nirvanix.com/sitefiles/1000/API.html#_Toc175999879">Namespaces</ulink>
  125. auf. Jeder Namespace kapselt eine Gruppe von zusammengehörenden Operationen. Nachdem
  126. man eine Instanz von <classname>Zend_Service_Nirvanix</classname> erhalten hat, muß die
  127. <code>getService()</code> Methode aufgerufen werden um einen Proxy für den Namespace zu
  128. erhalten den man verwenden will. Oben wird ein Proxy für den <code>IMFS</code>
  129. Namespace erstellt.
  130. </para>
  131. <para>
  132. Nachdem man den Proxy für den Namespace hat den man verwenden will, muß die Methode auf
  133. Ihm aufgerufen werden. Der Proxy erlaubt es jedes Kommando zu verwenden das in der
  134. REST API vorhanden ist. Der Proxy kann auch bequeme Methoden verfügbar machen, welche
  135. Kommandos des Web Services wrappen. Das obige Beispiel zeigt die Verwendung der
  136. bequemen IMFS Methoden um eine neue Datei zu erstellen, sie zu empfangen, diese
  137. Datei anzuzeigen und letztendlich die Datei zu löschen.
  138. </para>
  139. </sect2>
  140. <sect2 id="zend.service.nirvanix.understanding-proxy">
  141. <title>Den Proxy verstehen</title>
  142. <para>
  143. Im vorherigen Beispiel wurde die <code>getService()</code> Methode verwendet um ein
  144. Proxy Objekt zum <code>IMFS</code> Namespace zurückzugeben. Das Proxy Objekt erlaubt es
  145. das Nirvanix REST Service in einer Art zu verwenden die näher daran ist wie
  146. normalerweise ein PHP Methodenaufruf durchgeführt wird, gegenüber der Erstellung von
  147. eigenen HTTP Anfrage Objekten.
  148. </para>
  149. <para>
  150. Ein Proxy Objekt kann bequeme Methoden enthalten. Das sind Methoden die
  151. <classname>Zend_Service_Nirvanix</classname> bietet um die Verwendung der Nirvanix Web
  152. Services zu vereinfachen. Im vorigen Beispiel haben die Methoden
  153. <code>putContents()</code>, <code>getContents()</code>, und <code>unlink()</code> keine
  154. direkte Entsprechungen in der REST API. Das sind bequeme Methoden die von
  155. <classname>Zend_Service_Nirvanix</classname> angeboten werden um viel komplexere
  156. Operationen der REST API zu abstrahieren.
  157. </para>
  158. <para>
  159. Für alle anderen Methodenaufrufe zum Proxy Objekt konvertiert der Proxy dynamisch den
  160. Methodenaufruf in die entsprechende HTTP POST Anfrage zur REST API. Hierbei wird der
  161. Name der Methode als API Kommando verwendet, und ein assoziatives Array im ersten
  162. Argument als POST Parameter.
  163. </para>
  164. <para>
  165. Nehmen wir an das wir die REST API Methode <ulink
  166. url="http://developer.nirvanix.com/sitefiles/1000/API.html#_Toc175999923">RenameFile</ulink>
  167. aufrufen wollen welche keine bequeme Methode in
  168. <classname>Zend_Service_Nirvanix</classname> besitzen:
  169. </para>
  170. <programlisting language="php"><![CDATA[
  171. $auth = array('username' => 'Dein-Benutzername',
  172. 'password' => 'Dein-Passwort',
  173. 'appKey' => 'Dein-App-Schlüssel');
  174. $nirvanix = new Zend_Service_Nirvanix($auth);
  175. $imfs = $nirvanix->getService('IMFS');
  176. $result = $imfs->renameFile(array('filePath' => '/path/to/foo.txt',
  177. 'newFileName' => 'bar.txt'));
  178. ]]></programlisting>
  179. <para>
  180. Oben wird ein Proxy für den <code>IMFS</code> erstellt. Eine Methode,
  181. <code>renameFile()</code>, wird dann vom Proxy aufgerufen. Diese Methode existiert
  182. nicht als bequeme Methode im PHP Code, deswegen wird Sie durch <code>__call()</code>
  183. gefangen und in eine POST Anfrage für die REST API umgewandelt wo das assoziative
  184. Array als POST Parameter verwendet wird.
  185. </para>
  186. <para>
  187. Es ist in der Nirvanix API Dokumentation zu beachten das <code>sessionToken</code>
  188. für diese Methode benötigt wird, wir dieses aber nicht an das Proxy Objekt übbergeben
  189. haben. Es wird, der Bequemlichkeit halber, automatisch hinzugefügt.
  190. </para>
  191. <para>
  192. Das Ergebnis dieser Operation ist entweder ein
  193. <classname>Zend_Service_Nirvanix_Response</classname> Objekt das das von Nirvanix
  194. zurückgegebene XLP wrappt, oder <classname>Zend_Service_Nirvanix_Exception</classname>
  195. wenn ein Fehler aufgetreten ist.
  196. </para>
  197. </sect2>
  198. <sect2 id="zend.service.nirvanix.examining-results">
  199. <title>Ergebnisse erkunden</title>
  200. <para>
  201. Die Nirvanix REST API gibt Ihre Ergebnisse immer in einem XML zurück.
  202. <classname>Zend_Service_Nirvanix</classname> parst dieses XML mit der
  203. <code>SimpleXML</code> Erweiterung und dekoriert dann das sich ergebende
  204. <code>SimpleXMLElement</code> mit einem
  205. <classname>Zend_Service_Nirvanix_Response</classname> Objekt.
  206. </para>
  207. <para>
  208. Der einfachste Weg ein Ergebnis vom service zu betrachten ist die Verwendung der
  209. in PHP eingebauten Funktionen wie <code>print_r()</code>:
  210. </para>
  211. <programlisting language="php"><![CDATA[
  212. <?php
  213. $auth = array('username' => 'Dein-Benutzername',
  214. 'password' => 'Dein-Passwort',
  215. 'appKey' => 'Dein-App-Schlüssel');
  216. $nirvanix = new Zend_Service_Nirvanix($auth);
  217. $imfs = $nirvanix->getService('IMFS');
  218. $result = $imfs->putContents('/foo.txt', 'Vierzehn Bytes');
  219. print_r($result);
  220. ?>
  221. Zend_Service_Nirvanix_Response Object
  222. (
  223. [_sxml:protected] => SimpleXMLElement Object
  224. (
  225. [ResponseCode] => 0
  226. [FilesUploaded] => 1
  227. [BytesUploaded] => 14
  228. ))
  229. ]]></programlisting>
  230. <para>
  231. Auf jede Eigenschaft oder Methode des dekorierten <code>SimpleXMLElement</code>s kann
  232. zugegriffen werden. Im obigen Beispiel, könnte <code>$result->BytesUploaded</code>
  233. verwendet werden um die anzahl von empfangenen Bytes zu sehen. Sollte man auf das
  234. <code>SimpleXMLElement</code> direkt zugreifen wollen, kann einfach
  235. <code>$result->getSxml()</code> verwendet werden.
  236. </para>
  237. <para>
  238. Die üblichste Antwort von Nirvanix ist Erfolg (<code>ResponseCode</code> von Null).
  239. Es ist normalerweise nicht notwendig <code>ResponseCode</code> zu prüfen weil jedes
  240. nicht-null Ergebnis eine <classname>Zend_Service_Nirvanix_Exception</classname> wirft.
  241. Siehe das nächste Kapitel über die Behandlung von Fehlern.
  242. </para>
  243. </sect2>
  244. <sect2 id="zend.service.nirvanix.handling-errors">
  245. <title>Fehler behandeln</title>
  246. <para>
  247. Wenn Nirvanix verwendet wird, ist es wichtig Fehler zu vermeiden die vom Service
  248. zurückgegeben werden können und diese entsprechend zu behandeln.
  249. </para>
  250. <para>
  251. Alle Operationen gegenüber dem REST Service ergeben einen XML RückgabePayload der
  252. ein <code>ResponseCode</code> Element, wie im folgenden Beispiel, enthält:
  253. </para>
  254. <programlisting language="xml"><![CDATA[
  255. <Response>
  256. <ResponseCode>0</ResponseCode>
  257. </Response>
  258. ]]></programlisting>
  259. <para>
  260. Wenn <code>ResponseCode</code> Null ist, wie im obigen Beispiel, war die Operation
  261. erfolgreich. Wenn die Operation nicht erfolgreich war, ist <code>ResponseCode</code>
  262. nicht-Null und ein <code>ErrorMessage</code> Element sollte vorhanden sein.
  263. </para>
  264. <para>
  265. Um die Notwendigkeit zu verringern immer zu Prüfen ob <code>ResponseCode</code> Null
  266. ist, prüft <classname>Zend_Service_Nirvanix</classname> automatisch jede von Nirvanix
  267. zurückgegebene Antwort. Wenn <code>ResponseCode</code> einen Fehler zeigt, wird eine
  268. <classname>Zend_Service_Nirvanix_Exception</classname> geworfen.
  269. </para>
  270. <programlisting language="xml"><![CDATA[
  271. $auth = array('username' => 'your-username',
  272. 'password' => 'your-password',
  273. 'appKey' => 'your-app-key');
  274. $nirvanix = new Zend_Service_Nirvanix($auth);
  275. try {
  276. $imfs = $nirvanix->getService('IMFS');
  277. $imfs->unlink('/a-nonexistant-path');
  278. } catch (Zend_Service_Nirvanix_Exception $e) {
  279. echo $e->getMessage() . "\n";
  280. echo $e->getCode();
  281. }
  282. ]]></programlisting>
  283. <para>
  284. im obigen Beispiel ist <code>unlink()</code> eine bequeme Methode die das
  285. <code>DeleteFiles</code> der REST API wrappt. Der <code>filePath</code> Parameter wird
  286. vom <ulink
  287. url="http://developer.nirvanix.com/sitefiles/1000/API.html#_Toc175999918">DeleteFiles</ulink>
  288. Kommando benötigt und enthält einen Pfad der nicht existiert. Das wird in einer
  289. <classname>Zend_Service_Nirvanix</classname> Ausnahme resultieren die, mit der Nachricht
  290. "Invalid Path" und Code 70005, geworfen wird.
  291. </para>
  292. <para>
  293. Die <ulink url="http://developer.nirvanix.com/sitefiles/1000/API.html">Nirvanix API
  294. Dokumentation</ulink> beschreibt die mit jedem Kommando assoziierten Fehler.
  295. Abhängig von den eigenen Bedürfnissen kann jedes Kommando in einen <code>try</code>
  296. Block eingebettet werden oder aus Bequemlichkeit, viele Kommandos im selben
  297. <code>try</code> Block.
  298. </para>
  299. </sect2>
  300. </sect1>