Zend_Gdata_YouTube.xml 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15215 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.gdata.youtube">
  5. <title>Verwenden der YouTube Daten API</title>
  6. <para>
  7. Die YouTube Daten API bietet einen Lese- und Schreibzugriff auf YouTube Inhalte.
  8. Benutzer können nicht authentifizierte Anfragen zu Google Daten Feeds durchführen um Feeds von
  9. populären Videos, Kommentare, öffentliche Informationen über YouTube Benutzerprofilen,
  10. Benutzer PlayListen, Favoriten, Einschreibungen und so weiter zu erhalten.
  11. </para>
  12. <para>
  13. Für weitere Informationen über die YouTube Daten API schauen Sie in die offizielle
  14. <ulink url="http://code.google.com/apis/youtube/developers_guide_php.html">PHP Entwickler Dokumentation</ulink>
  15. auf code.google.com.
  16. </para>
  17. <sect2 id="zend.gdata.youtube.authentication">
  18. <title>Authentifizierung</title>
  19. <para>
  20. Die YouTube Daten API erlaubt aktuell einen nur-lesenden Zugriff auf öffentliche Daten, welcher
  21. keine Authentifizierung benötigt. Für alle schreibenden Anfragen muß sich ein Benutzer entweder
  22. mit ClientLogin oder AuthSub authentifizieren. Schauen Sie bitte in das
  23. <ulink url="http://code.google.com/apis/youtube/developers_guide_php.html#Authentication">Kapitel über Authentifizierung in der PHP Entwickler Dokumentation</ulink>
  24. für weitere Detail.
  25. </para>
  26. </sect2>
  27. <sect2 id="zend.gdata.youtube.developer_key">
  28. <title>Entwickler Schlüssel und Client ID</title>
  29. <para>
  30. Ein Entwickler Schlüssel identifiziert den QouTube Entwickler der die API Anfrage schickt.
  31. Eine Client ID identifiziert die Anwendung für Logging und Debugging Zwecke. Schauen Sie
  32. bitte auf
  33. <ulink url="http://code.google.com/apis/youtube/dashboard/">http://code.google.com/apis/youtube/dashboard/</ulink>
  34. um einen Entwickler Schlüssel und eine Client ID zu erhalten. Das angefügte Beispiel demonstriert
  35. wie der Entwickler Schlüssel und die Client ID an das
  36. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube.html">Zend_Gdata_YouTube</ulink>
  37. Service Pbjekt übergeben werden.
  38. </para>
  39. <example id="zend.gdata.youtube.developer_key.example">
  40. <title>Einen Entwicklerschlüssel und eine ClientID an Zend_Gdata_YouTube übergeben</title>
  41. <programlisting role="php"><![CDATA[
  42. $yt = new Zend_Gdata_YouTube($httpClient,
  43. $applicationId,
  44. $clientId,
  45. $developerKey);
  46. ]]></programlisting>
  47. </example>
  48. </sect2>
  49. <sect2 id="zend.gdata.youtube.videos">
  50. <title>Öffentliche Video Feeds empfangen</title>
  51. <para>
  52. Die YouTube Daten API bietet eine Vielzahl von Feeds die eine Liste von Videos zurückgeben, wie zum
  53. Beispiel Standard Feeds, Abhängige Videos, Antworten auf Videos, Videobewertungen, Benutzer Uploads,
  54. und Benutzer Favoriten. Zum Beispiel gibt der Benutzer Upload Feed alle Videos zurück die von einem
  55. speziellen Benutzer hochgeladen wurden. Sehen Sie in den
  56. <ulink url="http://code.google.com/apis/youtube/reference.html#Video_Feeds">You Tube Referenz Guide</ulink> für
  57. eine detailierte Liste aller vorhandenen Feeds.
  58. </para>
  59. <sect3 id="zend.gdata.youtube.videos.searching">
  60. <title>Suchen nach Videos durch Metadaten</title>
  61. <para>
  62. Man kann eine Liste von Videos erhalten die einem speziellen Suchkriterium entsprechen, indem
  63. die YouTubeQuery Klasse verwendet wird. Die folgende Abfrage schaut nach Videos welche das
  64. Wort "Katze" in Ihren Metadaten enthalten, beginnend mit dem 10ten Video und 20 Videos
  65. pro Seite anzeigt, sortiert nach der Anzahl der Ansichten.
  66. </para>
  67. <example id="zend.gdata.youtube.videos.searching.example">
  68. <title>Suchen nach Videos</title>
  69. <programlisting role="php"><![CDATA[
  70. $yt = new Zend_Gdata_YouTube();
  71. $query = $yt->newVideoQuery();
  72. $query->videoQuery = 'cat';
  73. $query->startIndex = 10;
  74. $query->maxResults = 20;
  75. $query->orderBy = 'viewCount';
  76. echo $query->queryUrl . "\n";
  77. $videoFeed = $yt->getVideoFeed($query);
  78. foreach ($videoFeed as $videoEntry) {
  79. echo "---------VIDEO----------\n";
  80. echo "Titel: " . $videoEntry->mediaGroup->title->text . "\n";
  81. echo "\nBeschreibung:\n";
  82. echo $videoEntry->mediaGroup->description->text;
  83. echo "\n\n\n";
  84. }
  85. ]]></programlisting>
  86. </example>
  87. <para>
  88. Für weitere Details über die verschiedenen Abfrageparameter, kann der
  89. <ulink url="http://code.google.com/apis/youtube/reference.html#Searching_for_videos">Referenz Guide</ulink>
  90. hilfreich sein. Die vorhandenen Hilfsfunktionen in
  91. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoQuery.html">
  92. <classname>Zend_Gdata_YouTube_VideoQuery</classname></ulink> für jeden dieser Parameter werden im
  93. <ulink url="http://code.google.com/apis/youtube/developers_guide_php.html#SearchingVideos">PHP Entwickler Guide</ulink>
  94. detailierter beschrieben.
  95. </para>
  96. </sect3>
  97. <sect3 id="zend.gdata.youtube.videos.searchingcategories">
  98. <title>Suchen nach Videos durch Kategorien und Tags/Schlüsselwörter</title>
  99. <para>
  100. Die Suche nach Videos in speziellen Kategorien wird durch die Erstellung einer
  101. <ulink url="http://code.google.com/apis/youtube/reference.html#Category_Search">
  102. speziell formatierten URL</ulink> durchgeführt. Um, zum Beispiel, nach Komödien-Videos zu
  103. suchen die das Schlüsselwort Hund enthalten:
  104. </para>
  105. <example id="zend.gdata.youtube.videos.searchingcategories.example">
  106. <title>Suchen nach Videos in speziellen Kategorien</title>
  107. <programlisting role="php"><![CDATA[
  108. $yt = new Zend_Gdata_YouTube();
  109. $query = $yt->newVideoQuery();
  110. $query->category = 'Comedy/Hund';
  111. echo $query->queryUrl . "\n";
  112. $videoFeed = $yt->getVideoFeed($query);
  113. ]]></programlisting>
  114. </example>
  115. </sect3>
  116. <sect3 id="zend.gdata.youtube.videos.standard">
  117. <title>Standard Feeds empfangen</title>
  118. <para>
  119. Die YouTube Daten API hat eine Anzahl an
  120. <ulink url="http://code.google.com/apis/youtube/reference.html#Standard_feeds">Standard Feeds</ulink>.
  121. Diese Standard Feeds können als
  122. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoFeed.html">Zend_Gdata_YouTube_VideoFeed</ulink>
  123. Objekte empfangen werden indem die spezifizierten URLs und die in der
  124. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube.html">Zend_Gdata_YouTube</ulink>
  125. Klasse vordefinierten Konstanten (zum Beispiel Zend_Gdata_YouTube::STANDARD_TOP_RATED_URI)
  126. oder die vordefinierten Hilfsmethoden verwendet verwendet werden (siehe das Codebeispiel anbei).
  127. </para>
  128. <para>
  129. Um die Top gereihten Videos zu erhalten kann die folgende Helfermethode verwendet werden:
  130. </para>
  131. <example id="zend.gdata.youtube.videos.standard.example-1">
  132. <title>Empfangen eines Standard Videofeeds</title>
  133. <programlisting role="php"><![CDATA[
  134. $yt = new Zend_Gdata_YouTube();
  135. $videoFeed = $yt->getTopRatedVideoFeed();
  136. ]]></programlisting>
  137. </example>
  138. <para>
  139. Es gibt auch Abfrageparameter um eine Zeitperiode zu spezifizieren über die der Standardfeed
  140. berechnet wird.
  141. </para>
  142. <para>
  143. Um zum Beispiel die Top gereihten Videos von Heute zu erhalten:
  144. </para>
  145. <example id="zend.gdata.youtube.videos.standard.example-2">
  146. <title>Verwenden von Zend_Gdata_YouTube_VideoQuery um Videos zu empfangen</title>
  147. <programlisting role="php"><![CDATA[
  148. $yt = new Zend_Gdata_YouTube();
  149. $query = $yt->newVideoQuery();
  150. $query->setTime('today');
  151. $videoFeed = $yt->getTopRatedVideoFeed($query);
  152. ]]></programlisting>
  153. </example>
  154. <para>
  155. Alternativ kann man den Feed erhalten indem die URL verwendet wird:
  156. </para>
  157. <example id="zend.gdata.youtube.videos.standard.example-3">
  158. <title>Empfangen eines Video Feeds durch die URL</title>
  159. <programlisting role="php"><![CDATA[
  160. $yt = new Zend_Gdata_YouTube();
  161. $url = 'http://gdata.youtube.com/feeds/standardfeeds/top_rated?time=today'
  162. $videoFeed = $yt->getVideoFeed($url);
  163. ]]></programlisting>
  164. </example>
  165. </sect3>
  166. <sect3 id="zend.gdata.youtube.videos.user">
  167. <title>Videos erhalten die von einem Benutzer hochgeladen wurden</title>
  168. <para>
  169. Man kann eine Liste von Videos erhalten die von einem bestimmten Benutzer hochgeladen wurden
  170. indem eine einfache Helfermethode verwendet wird. Dieses Beispiel empfängt Videos die vom
  171. Benutzer 'liz' hochgeladen wurden.
  172. </para>
  173. <example id="zend.gdata.youtube.videos.user.example">
  174. <title>Empfangen von Videos die von einem spezifischen Benutzer hochgeladen wurden</title>
  175. <programlisting role="php"><![CDATA[
  176. $yt = new Zend_Gdata_YouTube();
  177. $videoFeed = $yt->getUserUploads('liz');
  178. ]]></programlisting>
  179. </example>
  180. </sect3>
  181. <sect3 id="zend.gdata.youtube.videos.favorites">
  182. <title>Videos empfangen die von einem Benutzer bevorzugt werden</title>
  183. <para>
  184. Man kann eine Liste von bevorzugten Videos eines Benutzer erhalten indem eine einfache
  185. Helfermethode verwendet wird. Dieses Beispiel empfängt Videos die vom Benutzer 'liz'
  186. bevorzugt werden.
  187. </para>
  188. <example id="zend.gdata.youtube.videos.favorites.example">
  189. <title>Empfangen von den bevorzugten Videos eines Benutzers</title>
  190. <programlisting role="php"><![CDATA[
  191. $yt = new Zend_Gdata_YouTube();
  192. $videoFeed = $yt->getUserFavorites('liz');
  193. ]]></programlisting>
  194. </example>
  195. </sect3>
  196. <sect3 id="zend.gdata.youtube.videos.responses">
  197. <title>Videobewertungen für ein Video erhalten</title>
  198. <para>
  199. Man kann eine Liste von Videobewertungen eines Videos erhalten indem eine einfache
  200. Helfermethode verwendet wird. Dieses Beispiel empfängt Videobewertungen für ein Video
  201. mit der ID 'abc123813abc'.
  202. </para>
  203. <example id="zend.gdata.youtube.videos.responses.example">
  204. <title>Empfangen eines Feeds von Video Antworten</title>
  205. <programlisting role="php"><![CDATA[
  206. $yt = new Zend_Gdata_YouTube();
  207. $videoFeed = $yt->getVideoResponseFeed('abc123813abc');
  208. ]]></programlisting>
  209. </example>
  210. </sect3>
  211. </sect2>
  212. <sect2 id="zend.gdata.youtube.comments">
  213. <title>Videokommentare erhalten</title>
  214. <para>
  215. Die Kommentare für jedes YouTube Video können auf unterschiedlichen Wegen empfangen werden.
  216. Um die Kommentare für das Video mit der ID 'abc123813abc' zu empfangen kann der folgende Code
  217. verwendet werden:
  218. </para>
  219. <example id="zend.gdata.youtube.videos.comments.example-1">
  220. <title>Empfangen eines Feeds von Videokommentaren von einer Video ID</title>
  221. <programlisting role="php"><![CDATA[
  222. $yt = new Zend_Gdata_YouTube();
  223. $commentFeed = $yt->getVideoCommentFeed('abc123813abc');
  224. foreach ($commentFeed as $commentEntry) {
  225. echo $commentEntry->title->text . "\n";
  226. echo $commentEntry->content->text . "\n\n\n";
  227. }
  228. ]]></programlisting>
  229. </example>
  230. <para>
  231. Kommentare können für ein Video auch empfangen werden wenn man eine Kopie des
  232. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoEntry.html">Zend_Gdata_YouTube_VideoEntry</ulink>
  233. Objektes hat:
  234. </para>
  235. <example id="zend.gdata.youtube.videos.comments.example-2">
  236. <title>Empfangen eines Feeds von Videokommentaren von einem Zend_Gdata_YouTube_VideoEntry</title>
  237. <programlisting role="php"><![CDATA[
  238. $yt = new Zend_Gdata_YouTube();
  239. $videoEntry = $yt->getVideoEntry('abc123813abc');
  240. // Die ID des Videos in diesem Beispiel ist unbekannt, aber wir haben die URL
  241. $commentFeed = $yt->getVideoCommentFeed(null,
  242. $videoEntry->comments->href);
  243. ]]></programlisting>
  244. </example>
  245. </sect2>
  246. <sect2 id="zend.gdata.youtube.playlists">
  247. <title>PlayList Feeds erhalten</title>
  248. <para>
  249. Die YouTube Daten API bietet Informationen über Benutzer, inklusive Profile, PlayListen,
  250. Einschreibungen, und weitere.
  251. </para>
  252. <sect3 id="zend.gdata.youtube.playlists.user">
  253. <title>Die PlayListen eines Benutzer erhalten</title>
  254. <para>
  255. Die Bibliothek bietet eine Helfermethode um die PlayListen, die einem angegebenen Benutzer
  256. zugeordnet sind, zu erhalten. Um die PlayListen des Benutzers 'liz' zu erhalten kann der folgende
  257. Code verwendet werden:
  258. </para>
  259. <example id="zend.gdata.youtube.playlists.user.example">
  260. <title>Empfangen von Playlisten eines Benutzers</title>
  261. <programlisting role="php"><![CDATA[
  262. $yt = new Zend_Gdata_YouTube();
  263. $playlistListFeed = $yt->getPlaylistListFeed('liz');
  264. foreach ($playlistListFeed as $playlistEntry) {
  265. echo $playlistEntry->title->text . "\n";
  266. echo $playlistEntry->description->text . "\n";
  267. echo $playlistEntry->getPlaylistVideoFeedUrl() . "\n\n\n";
  268. }
  269. ]]></programlisting>
  270. </example>
  271. </sect3>
  272. <sect3 id="zend.gdata.youtube.playlists.special">
  273. <title>Eine spezielle PlayListe erhalten</title>
  274. <para>
  275. Die Bibliothek bietet eine Helfermethode um Videos zu erhalten die mit einer gegebenen
  276. PlayListe assoziiert sind. Um die PlayListe für einen speziellen PlayList Eintrag zu erhalten
  277. kann der folgende Code verwendet werden:
  278. </para>
  279. <example id="zend.gdata.youtube.playlists.special.example">
  280. <title>Empfangen von speziellen Playlisten</title>
  281. <programlisting role="php"><![CDATA[
  282. $feedUrl = $playlistEntry->getPlaylistVideoFeedUrl();
  283. $playlistVideoFeed = $yt->getPlaylistVideoFeed($feedUrl);
  284. ]]></programlisting>
  285. </example>
  286. </sect3>
  287. </sect2>
  288. <sect2 id="zend.gdata.youtube.subscriptions">
  289. <title>Eine Liste von Einschreibungen eines Benutzers erhalten</title>
  290. <para>
  291. Ein Benutzer kann verschiedene Arten von Einschreibungen besitzen: Kanal Einschreibungen, Tag
  292. Einschreibungen, oder Favoriten Einschreibungen. Ein
  293. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_SubscriptionEntry.html">Zend_Gdata_YouTube_SubscriptionEntry</ulink>
  294. wird verwendet um individuelle Einschreibungen zu repräsentieren.
  295. </para>
  296. <para>
  297. Um alle Einschreibungen für den Benutzer 'liz' zu erhalten kann der folgende Code verwendet werden:
  298. </para>
  299. <example id="zend.gdata.youtube.subscriptions.example">
  300. <title>Empfangen aller Einschreibungen eines Benutzers</title>
  301. <programlisting role="php"><![CDATA[
  302. $yt = new Zend_Gdata_YouTube();
  303. $subscriptionFeed = $yt->getSubscriptionFeed('liz');
  304. foreach ($subscriptionFeed as $subscriptionEntry) {
  305. echo $subscriptionEntry->title->text . "\n";
  306. }
  307. ]]></programlisting>
  308. </example>
  309. </sect2>
  310. <sect2 id="zend.gdata.youtube.profile">
  311. <title>Ein Benutzerprofil erhalten</title>
  312. <para>
  313. Die öffentlichen Profil Informationen kann man für jeden YouTube Benutzer erhalten. Um das Profil
  314. für den Benutzer 'liz' zu erhalten kann der folgende Code verwendet werden:
  315. </para>
  316. <example id="zend.gdata.youtube.profile.example">
  317. <title>Empfangen des Profils eines Benutzers</title>
  318. <programlisting role="php"><![CDATA[
  319. $yt = new Zend_Gdata_YouTube();
  320. $userProfile = $yt->getUserProfile('liz');
  321. echo "Benutzername: " . $userProfile->username->text . "\n";
  322. echo "Alter: " . $userProfile->age->text . "\n";
  323. echo "Heimatstadt: " . $userProfile->hometown->text . "\n";
  324. ]]></programlisting>
  325. </example>
  326. </sect2>
  327. <sect2 id="zend.gdata.youtube.uploads">
  328. <title>Videos auf YouTube hochladen</title>
  329. <para>
  330. Stellen Sie sicher das Sie die Diagramme im
  331. <ulink url="http://code.google.com/apis/youtube/developers_guide_protocol.html#Process_Flows_for_Uploading_Videos">Protokoll Guide</ulink>
  332. auf code.google.com für eine Übersicht des Upload Prozesses betrachtet haben. Das Hochladen
  333. von Videos kann auf 2 Wegen durchgeführt werden: Entweder durch das direkte Hochladen des
  334. Videos oder durch das Senden der Video Meta-Daten und indem der Benutzer das Video über ein
  335. HTML Formular hochlädt.
  336. </para>
  337. <para>
  338. Um ein Video direkt hochzuladen, muß zuerst ein neues
  339. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoEntry.html">Zend_Gdata_YouTube_VideoEntry</ulink>
  340. Objekt erstellt und einige benötigte Meta-Daten spezifiziert werden. Das folgende Beispiel zeigt
  341. das Hochladen des Quicktime Videos "mytestmovie.mov" auf YouTube mit den folgenden Eigenschaften:
  342. </para>
  343. <table id="zend.gdata.youtube.uploads.metadata">
  344. <title>Metadaten die im folgenden Code-Beispiel verwendet werden</title>
  345. <tgroup cols="2" align="left" colsep="1" rowsep="1">
  346. <thead>
  347. <row>
  348. <entry>Eigenschaft</entry>
  349. <entry>Wert</entry>
  350. </row>
  351. </thead>
  352. <tbody>
  353. <row>
  354. <entry>Title</entry>
  355. <entry>My Test Movie</entry>
  356. </row>
  357. <row>
  358. <entry>Category</entry>
  359. <entry>Autos</entry>
  360. </row>
  361. <row>
  362. <entry>Keywords</entry>
  363. <entry>cars, funny</entry>
  364. </row>
  365. <row>
  366. <entry>Description</entry>
  367. <entry>My description</entry>
  368. </row>
  369. <row>
  370. <entry>Filename</entry>
  371. <entry>mytestmovie.mov</entry>
  372. </row>
  373. <row>
  374. <entry>File MIME type</entry>
  375. <entry>video/quicktime</entry>
  376. </row>
  377. <row>
  378. <entry>Video private?</entry>
  379. <entry>false</entry>
  380. </row>
  381. <row>
  382. <entry>Video location</entry>
  383. <entry>37, -122 (lat, long)</entry>
  384. </row>
  385. <row>
  386. <entry>Developer Tags</entry>
  387. <entry>mydevelopertag, anotherdevelopertag</entry>
  388. </row>
  389. </tbody>
  390. </tgroup>
  391. </table>
  392. <para>
  393. Der folgende Code erzeugt einen leeren
  394. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoEntry.html">Zend_Gdata_YouTube_VideoEntry</ulink>
  395. der Hochgeladen werden kann. Ein
  396. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_App_MediaFileSource.html">Zend_Gdata_App_MediaFileSource</ulink> object is then used to hold the actual video file. Under the hood, the <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_Extension_MediaGroup.html">Zend_Gdata_YouTube_Extension_MediaGroup</ulink>
  397. Objekt wird verwendet um alle Metadaten des Videos zu speichern. Die anbei beschriebenen
  398. Helfermethoden erlauben es die Metadaten des Videos zu setzen ohne das man sich um das Medien
  399. Gruppen Objekt kümmern muß. $uploadUrl ist der Ort an den der neue Eintrag gepostet wird. Er kann
  400. entweder durch $userName des aktuell authentifizierten Benutzers spezifiziert werden, oder,
  401. alternativ indem einfach der String 'default' verwendet wird um auf den aktuell authentifizierten
  402. Benutzer zu verweisen.
  403. </para>
  404. <example id="zend.gdata.youtube.uploads.example">
  405. <title>Ein Video hochladen</title>
  406. <programlisting role="php"><![CDATA[
  407. $yt = new Zend_Gdata_YouTube($httpClient);
  408. $myVideoEntry = new Zend_Gdata_YouTube_VideoEntry();
  409. $filesource = $yt->newMediaFileSource('mytestmovie.mov');
  410. $filesource->setContentType('video/quicktime');
  411. $filesource->setSlug('mytestmovie.mov');
  412. $myVideoEntry->setMediaSource($filesource);
  413. $myVideoEntry->setVideoTitle('My Test Movie');
  414. $myVideoEntry->setVideoDescription('My Test Movie');
  415. // Beachte das category eine gültige YouTube Kategorie sein muß !
  416. $myVideoEntry->setVideoCategory('Comedy');
  417. // Setzt Keywords, beachte das es ein Komma getrennter String ist
  418. // und das keines der Schlüsselwörter ein Leerzeichen enthalten darf
  419. $myVideoEntry->SetVideoTags('cars, funny');
  420. // Optional Entwickler Tags setzen
  421. $myVideoEntry->setVideoDeveloperTags(array('mydevelopertag',
  422. 'anotherdevelopertag'));
  423. // Optional den Ort des Videos setzen
  424. $yt->registerPackage('Zend_Gdata_Geo');
  425. $yt->registerPackage('Zend_Gdata_Geo_Extension');
  426. $where = $yt->newGeoRssWhere();
  427. $position = $yt->newGmlPos('37.0 -122.0');
  428. $where->point = $yt->newGmlPoint($position);
  429. $myVideoEntry->setWhere($where);
  430. // URI hochladen für den aktuell authentifizierten Benutzer
  431. $uploadUrl =
  432. 'http://uploads.gdata.youtube.com/feeds/users/default/uploads';
  433. // Versuch das Video hochzuladen, eine Zend_Gdata_App_HttpException fangen wenn
  434. // Sie vorhanden ist oder nur eine reguläre Zend_Gdata_App_Exception
  435. try {
  436. $newEntry = $yt->insertEntry($myVideoEntry,
  437. $uploadUrl,
  438. 'Zend_Gdata_YouTube_VideoEntry');
  439. } catch (Zend_Gdata_App_HttpException $httpException) {
  440. echo $httpException->getRawResponseBody();
  441. } catch (Zend_Gdata_App_Exception $e) {
  442. echo $e->getMessage();
  443. }
  444. ]]></programlisting>
  445. </example>
  446. <para>
  447. Um ein Video als privat hochzuladen muß einfach $myVideoEntry->setVideoPrivate(); verwendet
  448. werden; bevor das Hochladen durchgeführt wird. $videoEntry->isVideoPrivate() kann verwendet
  449. werden um zu prüfen ob ein Video Eintrag privat ist oder nicht.
  450. </para>
  451. </sect2>
  452. <sect2 id="zend.gdata.youtube.uploads.browser">
  453. <title>Browser-basierender Upload</title>
  454. <para>
  455. Browser-basierendes hochladen wird fast auf die gleiche Weise durchgeführt wie direktes
  456. Hochladen, ausser das man kein
  457. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_App_MediaFileSource.html">Zend_Gdata_App_MediaFileSource</ulink>
  458. Objekt an den
  459. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoEntry.html">Zend_Gdata_YouTube_VideoEntry</ulink>
  460. anhängt den man erstellt. Stattdessen überträgt man einfach alle Metadaten des Videos um ein
  461. Token Element zurück zu erhalten welches verwendet werden kann um ein HTML Upload Formular
  462. zu erstellen.
  463. </para>
  464. <example id="zend.gdata.youtube.uploads.browser.example-1">
  465. <title>Browser-basierender Upload</title>
  466. <programlisting role="php"><![CDATA[
  467. $yt = new Zend_Gdata_YouTube($httpClient);
  468. $myVideoEntry= new Zend_Gdata_YouTube_VideoEntry();
  469. $myVideoEntry->setVideoTitle('My Test Movie');
  470. $myVideoEntry->setVideoDescription('My Test Movie');
  471. // Beachte das die Kategorie eine gültige YouTube Kategorie sein muß !
  472. $myVideoEntry->setVideoCategory('Comedy');
  473. $myVideoEntry->SetVideoTags('cars, funny');
  474. $tokenHandlerUrl = 'http://gdata.youtube.com/action/GetUploadToken';
  475. $tokenArray = $yt->getFormUploadToken($myVideoEntry, $tokenHandlerUrl);
  476. $tokenValue = $tokenArray['token'];
  477. $postUrl = $tokenArray['url'];
  478. ]]></programlisting>
  479. </example>
  480. <para>
  481. Der obige Code gibt einen Link und ein Token aus das verwendet wird um ein HTML Formular zu
  482. erstellen und im Browser des Benutzers anzuzeigen. Ein einfaches Beispielformular wird unten
  483. gezeigt mit $tokenValue welches den Inhalt des zurückgegebenen Token Elements darstellt,
  484. welches wie gezeigt, oben von $myVideoEntry empfangen wird. Damit der Benutzer, nachdem das
  485. Formular übermittelt wurde, auf die Website umgeleitet wird, muß ein $nextUrl Parameter an die
  486. $postUrl von oben angehängt werden, was auf die gleiche Weise funktioniert wie der $next
  487. Parameter eines AuthSub Links. Der einzige Unterschied ist hier das, statt eines
  488. einmal zu verwendenden Tokens, ein Status und eine ID Variable in der URL zurückgegeben
  489. werden.
  490. </para>
  491. <example id="zend.gdata.youtube.uploads.browser.example-2">
  492. <title>Browser-basierender Upload: Erstellen des HTML Formulars</title>
  493. <programlisting role="php"><![CDATA[
  494. // Platzieren um den Benutzer nach dem Upload umzuleiten
  495. $nextUrl = 'http://mysite.com/youtube_uploads';
  496. $form = '<form action="'. $postUrl .'?nexturl='. $nextUrl .
  497. '" method="post" enctype="multipart/form-data">'.
  498. '<input name="file" type="file"/>'.
  499. '<input name="token" type="hidden" value="'. $tokenValue .'"/>'.
  500. '<input value="Video Daten hochladen" type="submit" />'.
  501. '</form>';
  502. ]]></programlisting>
  503. </example>
  504. </sect2>
  505. <sect2 id="zend.gdata.youtube.uploads.status">
  506. <title>Den Upload Status prüfen</title>
  507. <para>
  508. Nachdem ein Video hochgeladen wurde, wird es im Upload Feed des authentifizierten Benutzer
  509. unmittelbar sichtbar sein. Trotzdem wird es auf der Site nicht öffentlich sein solange es nicht
  510. bearbeitet wurde. Videos die ausgeschlossen oder nicht erfolgreich hochgeladen wurden werden
  511. auch nur im Upload Feed des authentifizierten Benutzers sichtbar sein. Der folgende Code
  512. prüft den Status eines
  513. <ulink url="http://framework.zend.com/apidoc/core/Zend_Gdata/Zend_Gdata_YouTube_VideoEntry.html">Zend_Gdata_YouTube_VideoEntry</ulink>
  514. um zu sehen ob er jetzt noch nicht live ist oder ob er nicht akzeptiert wurde.
  515. </para>
  516. <example id="zend.gdata.youtube.uploads.status.example">
  517. <title>Den Status von Video Uploads checken</title>
  518. <programlisting role="php"><![CDATA[
  519. try {
  520. $control = $videoEntry->getControl();
  521. } catch (Zend_Gdata_App_Exception $e) {
  522. echo $e->getMessage();
  523. }
  524. if ($control instanceof Zend_Gdata_App_Extension_Control) {
  525. if ($control->getDraft() != null &&
  526. $control->getDraft()->getText() == 'yes') {
  527. $state = $videoEntry->getVideoState();
  528. if ($state instanceof Zend_Gdata_YouTube_Extension_State) {
  529. print 'Upload Status: '
  530. . $state->getName()
  531. .' '. $state->getText();
  532. } else {
  533. print 'Die Status Informationen des Videos konnten bis jetzt nicht'
  534. . ' empfangen werden. Bitte versuchen Sie es etwas später'
  535. . ' nochmals.\n";
  536. }
  537. }
  538. }
  539. ]]></programlisting>
  540. </example>
  541. </sect2>
  542. <sect2 id="zend.gdata.youtube.other">
  543. <title>Andere Funktionen</title>
  544. <para>
  545. Zusätzlich zur oben beschriebenen Funktionalität, enthält die YouTube API viele andere Funktionen
  546. die es erlauben Video Metadaten zu verändern, Video Einträge zu löschen und den kompletten
  547. Bereich an Community Features der Site zu verwenden. Einige der Community Features die durch
  548. die API verändert werden können enthalten: Ratings, Kommentare, Playlisten, Einschreibungen,
  549. Benutzer Profile, Kontakte und Nachrichten.
  550. </para>
  551. <para>
  552. Bitte schauen Sie in die komplette Dokumentation die im
  553. <ulink url="http://code.google.com/apis/youtube/developers_guide_php.html">PHP Entwickler Guide</ulink>
  554. auf code.google.com zu finden ist.
  555. </para>
  556. </sect2>
  557. </sect1>