Zend_Service_Simpy.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 20818 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.service.simpy">
  5. <title>Zend_Service_Simpy</title>
  6. <sect2 id="zend.service.simpy.introduction">
  7. <title>Einführung</title>
  8. <para>
  9. <classname>Zend_Service_Simpy</classname> ist ein schlanker Wrapper für das freie REST
  10. <acronym>API</acronym> des Simpy Lesezeichen-Services.
  11. </para>
  12. <para>
  13. Um <classname>Zend_Service_Simpy</classname> zu nutzen, solltest du bereits ein
  14. Simpy-Konto besitzen. Falls dies nicht der Fall ist, kannst du dies auf der
  15. <ulink url="http://simpy.com">Simpy Webseite</ulink> tun. Für weitere Informationen über
  16. das Simpy REST <acronym>API</acronym>, kannst du in der
  17. <ulink url="http://www.simpy.com/doc/api/rest">Simpy REST <acronym>API</acronym>
  18. Dokumentation</ulink> nachlesen.
  19. </para>
  20. <para>
  21. Das Simpy REST <acronym>API</acronym> erlaubt es dem Entwickler, mit verschiedenen
  22. Aspekten des Services, welche die Simpy Webseite bietet, zu interagieren. Diese
  23. Sektionen zeigen dir, wie man <classname>Zend_Service_Simpy</classname> in jedem dieser
  24. Bereiche nutzen kann.
  25. <itemizedlist>
  26. <listitem>
  27. <para>Links: Erstellen, Laden, Aktualisieren, Löschen</para>
  28. </listitem>
  29. <listitem>
  30. <para>Tags: Laden, Löschen, Umbenennen, Zusammenfassen, Splitten</para>
  31. </listitem>
  32. <listitem>
  33. <para>Notes: Erstellen, Laden, Aktualisieren, Löschen</para>
  34. </listitem>
  35. <listitem>
  36. <para>Watchlists: Holen, Alle holen</para>
  37. </listitem>
  38. </itemizedlist>
  39. </para>
  40. </sect2>
  41. <sect2 id="zend.service.simpy.links">
  42. <title>Links</title>
  43. <para>
  44. Beim Anfragen von Links, werden diese absteigend nach deren Datum - wann es
  45. hinzugefügt wurde - sortiert. Es kann nach Links anhand des Titels, des Spitznamens,
  46. der Tags, der Notizen oder sogar des Inhalts der verknüpften Webseite gesucht werden.
  47. Simpy erlaubt es, jegliche oder alle dieser Felder mit Phrasen, booleschen
  48. Operatoren und Wildcards zu durchsuchen. Siehe in den
  49. <ulink url="http://www.simpy.com/faq#searchSyntax">Suchsyntax</ulink>- und
  50. <ulink url="http://www.simpy.com/faq#searchFieldsLinks">Suchfelder</ulink>-Sektionen
  51. der Simipy FAQ für weitere Informationen.
  52. </para>
  53. <example id="zend.service.simpy.links.querying">
  54. <title>Abfragen von Links</title>
  55. <programlisting language="php"><![CDATA[
  56. $simpy = new Zend_Service_Simpy('yourusername', 'yourpassword');
  57. /* Suche nach den 10 letzten hinzugefügten Links */
  58. $linkQuery = new Zend_Service_Simpy_LinkQuery();
  59. $linkQuery->setLimit(10);
  60. /* Holen und darstellen */
  61. $linkSet = $simpy->getLinks($linkQuery);
  62. foreach ($linkSet as $link) {
  63. echo '<a href="';
  64. echo $link->getUrl();
  65. echo '">';
  66. echo $link->getTitle();
  67. echo '</a><br />';
  68. }
  69. /* Suche nach den 5 letzten hinzugefügten Links mit 'PHP'
  70. im Titel */
  71. $linkQuery->setQueryString('title:PHP');
  72. $linkQuery->setLimit(5);
  73. /* Suche nach allen Links mit 'French' im Titel und
  74. 'lanuage' in den Tags */
  75. $linkQuery->setQueryString('+title:French +tags:language');
  76. /* Suche nach allen Links mit 'French' im Titel und ohne
  77. 'travel' in den Tags */
  78. $linkQuery->setQueryString('+title:French -tags:travel');
  79. /* Suche nach allen Links, die am 9.12.2006 hinzugefügt wurden */
  80. $linkQuery->setDate('2006-12-09');
  81. /* Suche nach allen Links, die nach dem 9.12.2006 hinzugefügt wurden (
  82. das Datum ist nicht eingeschlossen) */
  83. $linkQuery->setAfterDate('2006-12-09');
  84. /* Suche nach allen Links, die vom dem 9.12.2006 hinzugefügt wurden (
  85. das angegebene Datum ist ausgeschlossen) */
  86. $linkQuery->setBeforeDate('2006-12-09');
  87. /* Suche nach allen Links, die zwischen dem 1.12.2006 und dem 9.12.2006
  88. hinzugefügt wurden (die beiden Daten sind dabei ausgeschlossen) */
  89. $linkQuery->setBeforeDate('2006-12-01');
  90. $linkQuery->setAfterDate('2006-12-09');
  91. ]]></programlisting>
  92. </example>
  93. <para>
  94. Links werden eindeutig durch ihren <acronym>URL</acronym> angezeigt. In anderen Worten,
  95. falls ein Versuch gemacht wird, einen Link zu speichern, der denselben
  96. <acronym>URL</acronym> hat wie ein bereits existierender Link, werden die Daten des
  97. alten Links mit den neuen Daten überschrieben.
  98. </para>
  99. <example id="zend.service.simpy.links.modifying">
  100. <title>Modifizieren von Links</title>
  101. <programlisting language="php"><![CDATA[
  102. $simpy = new Zend_Service_Simpy('yourusername', 'yourpassword');
  103. /* Speichern eines link */
  104. $simpy->saveLink(
  105. 'Zend Framework' // Titel
  106. 'http://framework.zend.com', // URL
  107. Zend_Service_Simpy_Link::ACCESSTYPE_PUBLIC, // Zugriffstyp
  108. 'zend, framework, php' // Tags
  109. 'Zend Framework home page' // Alternativer Titel
  110. 'This site rocks!' // Notiz
  111. );
  112. /* Überschreibe den existierenden Link mit neuen Daten */
  113. $simpy->saveLink(
  114. 'Zend Framework'
  115. 'http://framework.zend.com',
  116. // der Zugriffstyp wurde geändert
  117. Zend_Service_Simpy_Link::ACCESSTYPE_PRIVATE,
  118. // Die Reihenfolge der Tags hat sich geändert
  119. 'php, zend, framework'
  120. // Alternativer Titel wurde geändert
  121. 'Zend Framework'
  122. // Notiz hat sich geändert
  123. 'This site REALLY rocks!'
  124. );
  125. /* Den Link löschen */
  126. $simpy->deleteLink('http://framework.zend.com');
  127. /* Ein wirklich einfacher Weg den Frühjahrsputz
  128. bei deinen Links zu machen ;-) */
  129. $linkSet = $this->_simpy->getLinks();
  130. foreach ($linkSet as $link) {
  131. $this->_simpy->deleteLink($link->getUrl());
  132. }
  133. ]]></programlisting>
  134. </example>
  135. </sect2>
  136. <sect2 id="zend.service.simpy.tags">
  137. <title>Tags</title>
  138. <para>
  139. Wenn die Tags zurückgegeben werden, werden sie in absteigender
  140. Reihenfolge (d.h. der größte zuerst) nach der Häufigkeit der
  141. Benutzung durch die Links sortiert.
  142. </para>
  143. <example id="zend.service.simpy.tags.working">
  144. <title>Arbeiten mit Tags</title>
  145. <programlisting language="php"><![CDATA[
  146. $simpy = new Zend_Service_Simpy('yourusername', 'yourpassword');
  147. /* Speicher einen Link mit Tags */
  148. $simpy->saveLink(
  149. 'Zend Framework' // Titel
  150. 'http://framework.zend.com', // URL
  151. Zend_Service_Simpy_Link::ACCESSTYPE_PUBLIC, // Zugriffstyp
  152. 'zend, framework, php' // Tags
  153. );
  154. /* Hole eine Liste mit allen Tags, die von Links und
  155. Notizen genutzt werden */
  156. $tagSet = $simpy->getTags();
  157. /* Stelle jeden Tag mit der Anzahl der Links, die ihn nutzen, dar */
  158. foreach ($tagSet as $tag) {
  159. echo $tag->getTag();
  160. echo ' - ';
  161. echo $tag->getCount();
  162. echo '<br />';
  163. }
  164. /* Entferne das 'zend'-Tag von allen Links, die es benutzen */
  165. $simpy->removeTag('zend');
  166. /* Nenne das 'framework'-Tag zu 'frameworks' um */
  167. $simpy->renameTag('framework', 'frameworks');
  168. /* Splitte das 'frameworks'-Tag in 'framework' und
  169. 'development' auf. D.h. dass alle Links, die 'frameworks'
  170. als Tag besitzen, nunmehr stattdessen 'framework' und 'development'
  171. besitzen */
  172. $simpy->splitTag('frameworks', 'framework', 'development');
  173. /* Fasse 'framework' und 'development' wieder zu 'frameworks'
  174. zusammen; vereinfacht ist es das Gegenteil, ein Tag zu splitten */
  175. $simpy->mergeTags('framework', 'development', 'frameworks');
  176. ]]></programlisting>
  177. </example>
  178. </sect2>
  179. <sect2 id="zend.service.simpy.notes">
  180. <title>Notizen</title>
  181. <para>
  182. Notizen können gespeichert, geladen und gelöscht werden. Sie sind
  183. eindeutig durch eine numerische ID definiert.
  184. </para>
  185. <example id="zend.service.simpy.notes.working">
  186. <title>Arbeiten mit Notizen</title>
  187. <programlisting language="php"><![CDATA[
  188. $simpy = new Zend_Service_Simpy('yourusername', 'yourpassword');
  189. /* Eine Notiz speichern */
  190. $simpy->saveNote(
  191. 'Test Note', // Titel
  192. 'test,note', // Tags
  193. 'This is a test note.' // Beschreibung
  194. );
  195. /* Eine bereits existierende Notiz überschreiben */
  196. $simpy->saveNote(
  197. 'Updated Test Note', // Titel
  198. 'test,note,updated', // Tags
  199. 'This is an updated test note.', // Beschreibung
  200. $note->getId() // Eindeutige ID
  201. );
  202. /* Suche nach den 10 letzten hinzugefügten Notizen */
  203. $noteSet = $simpy->getNotes(null, 10);
  204. /* Zeige diese Notizen an */
  205. foreach ($noteSet as $note) {
  206. echo '<p>';
  207. echo $note->getTitle();
  208. echo '<br />';
  209. echo $note->getDescription();
  210. echo '<br >';
  211. echo $note->getTags();
  212. echo '</p>';
  213. }
  214. /* Suche nach allen Notizen mit 'PHP' im Titel */
  215. $noteSet = $simpy->getNotes('title:PHP');
  216. /* Suche nach allen Notizen mit 'PHP' im Titel und ohne
  217. 'framework' in der Beschreibung */
  218. $noteSet = $simpy->getNotes('+title:PHP -description:framework');
  219. /* Löschen einer Notiz */
  220. $simpy->deleteNote($note->getId());
  221. ]]></programlisting>
  222. </example>
  223. </sect2>
  224. <sect2 id="zend.service.simpy.watchlists">
  225. <title>Watchlists</title>
  226. <para>
  227. Watchlisten können durch das <acronym>API</acronym> nicht erstellt oder entfernt
  228. werden, sondern lediglich zurückgegeben. Folglich musst du eine
  229. Watchlist über die Simpy Webseite erstellen, bevor du diese
  230. über das <acronym>API</acronym> nutzt.
  231. </para>
  232. <example id="zend.service.simpy.watchlists.retrieving">
  233. <title>Zurückgeben von Watchlisten</title>
  234. <programlisting language="php"><![CDATA[
  235. $simpy = new Zend_Service_Simpy('yourusername', 'yourpassword');
  236. /* Hole eine Liste von allen Watchlisten */
  237. $watchlistSet = $simpy->getWatchlists();
  238. /* Zeige die Daten jeder Watchlist an */
  239. foreach ($watchlistSet as $watchlist) {
  240. echo $watchlist->getId();
  241. echo '<br />';
  242. echo $watchlist->getName();
  243. echo '<br />';
  244. echo $watchlist->getDescription();
  245. echo '<br />';
  246. echo $watchlist->getAddDate();
  247. echo '<br />';
  248. echo $watchlist->getNewLinks();
  249. echo '<br />';
  250. foreach ($watchlist->getUsers() as $user) {
  251. echo $user;
  252. echo '<br />';
  253. }
  254. foreach ($watchlist->getFilters() as $filter) {
  255. echo $filter->getName();
  256. echo '<br />';
  257. echo $filter->getQuery();
  258. echo '<br />';
  259. }
  260. }
  261. /* Hole eine spezielle Watchlist anhand einer ID */
  262. $watchlist = $simpy->getWatchlist($watchlist->getId());
  263. $watchlist = $simpy->getWatchlist(1);
  264. ]]></programlisting>
  265. </example>
  266. </sect2>
  267. </sect1>