Using Google Base

Utilisation des albums Web Picasa

Les albums Web Picasa représentent un service Google permettant de maintenir à jour des albums photos, tout en pouvant récupérer des photos de l'album d'un membre. L'API propose des services pour ajouter, mettre à jour ou supprimer des photos d'un album, de même que gérer des mots-clés ou des commentaires sur des images(photos).

L'accès public à un album, en lecture donc, n'est pas sujet à demande d'authentification. En revanche, toute autre manipulation telle que la mise à jour ou la suppression, nécessitera que vous vous authentifiez.

Pour plus d'informations sur l'API, voyez » l'API Picasa Web Albums.

Note: Authentification
L'API propose les deux modes d'authentification, AuthSub (recommandé) et ClientAuth. Pour toute opération d'écriture vers le service, une authentification sera demandée, la lecture est elle, libre, au regard de l'API.

Se connecter au service

L'API Picasa, comme tous les autres services Web Google Gdata, est basée sur le protocole Atom Publishing Protocol (APP), et le XML. Le trafic entre le client et le serveur se fait sur HTTP, et autorise des connexions authentifiées, ou non.

Avant tout, il faut donc se connecter. Ceci se fait en deux étapes : créer un client HTTP, et insérer un Zend_Gdata_Photos dans celui-ci.

Authentification

L'API propose un accès à la fois aux données publiques, et aux données privées. Les données publiques ne requièrent pas d'authentification, mais ne sont accessibles qu'en lecture seule. L'écriture et l'accès aux données privées requièrent une authentification, qui peut s'effectuer de trois manières différentes :

  • ClientAuth permet une authentification directe en donnant un couple login/password. Les utilisateurs devront donc renseigner ces 2 paramètres sur votre site directement.

  • AuthSub permet l'authentification en passant par un serveur proxy de Google. Les risques liés à la sécurité sont donc moindre avec cette méthode.

La librairie Zend_Gdata permet ces 2 types d'authentification. Le reste de ce chapitre supposera que vous soyez habitué à l'authentification avec les service Web Google GData. Si ce n'est pas le cas, nous vous conseillons de consulter la section authentification de ce manuel, ou encore » le guide d'authentification Google GData webservices API.

Créer une instance du service

Pour interagir avec les serveurs, la classe Zend_Gdata_Photos sera nécessaire. Elle abstrait toute la logique de communication avec le Protocol Atom Publishing vers les serveurs de Google.

Une fois que vous avez choisi une méthode d'authentification, vous devez créer une instance de Zend_Gdata_Photos. Le constructeur prend en paramètre une instance de Zend_Http_Client. Cette classe est l'interface AuthSub ou ClientAuth authentification. Si vous ne passez pas cette instance en argument, alors une instance de Zend_Http_Client sera crée automatiquement, mais en mode non authentifié.

Voici un exemple qui démontre comment créer une classe vers le service avec le procédé d'authentification ClientAuth :

  1. // Paramètres pour ClientAuth authentification
  2. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  3. $user = "sample.user@gmail.com";
  4. $pass = "pa$$w0rd";
  5.  
  6. // Création d'une client HTTP authentifié
  7. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  8.  
  9. // Création de l'instance du service
  10. $service = new Zend_Gdata_Photos($client);

Au sujet du procédé AuthSub, voici la démarche :

  1.  
  2. /**
  3. * Retourne l'URL complet de la page actuelle,
  4. * en fonction des variables d'environnement
  5. *
  6. * Env variables utilisées:
  7. * $_SERVER['HTTPS'] = (on|off|)
  8. * $_SERVER['HTTP_HOST'] = value of the Host: header
  9. * $_SERVER['SERVER_PORT'] = port number (only used if not http/80,https/443)
  10. * $_SERVER['REQUEST_URI'] = the URI after the method of the HTTP request
  11. *
  12. * @return string Current URL
  13. */
  14. function getCurrentUrl()
  15. {
  16.     global $_SERVER;
  17.  
  18.     /**
  19.      * Filtre php_self pour éviter des problèmes de sécurité
  20.      */
  21.     $php_request_uri = htmlentities(substr($_SERVER['REQUEST_URI'], 0,
  22.     strcspn($_SERVER['REQUEST_URI'], "\n\r")), ENT_QUOTES);
  23.  
  24.     if (isset($_SERVER['HTTPS'])
  25.      && strtolower($_SERVER['HTTPS']) == 'on') {
  26.         $protocol = 'https://';
  27.     } else {
  28.         $protocol = 'http://';
  29.     }
  30.     $host = $_SERVER['HTTP_HOST'];
  31.     if ($_SERVER['SERVER_PORT'] != '' &&
  32.         (($protocol == 'http://' && $_SERVER['SERVER_PORT'] != '80') ||
  33.         ($protocol == 'https://' && $_SERVER['SERVER_PORT'] != '443'))) {
  34.             $port = ':' . $_SERVER['SERVER_PORT'];
  35.     } else {
  36.         $port = '';
  37.     }
  38.     return $protocol . $host . $port . $php_request_uri;
  39. }
  40.  
  41. /**
  42. * Retourne l'URL AuthSub que l'utilisateur doit visiter
  43. * pour authentifier ses requêtes
  44. *
  45. * Utilise getCurrentUrl() pour récupérer le prochain URL
  46. * vers lequel l'utilisateur sera redirigé après
  47. * s'être authentifié.
  48. *
  49. * @return string AuthSub URL
  50. */
  51. function getAuthSubUrl()
  52. {
  53.     $next = getCurrentUrl();
  54.     $scope = 'http://picasaweb.google.com/data';
  55.     $secure = false;
  56.     $session = true;
  57.     return Zend_Gdata_AuthSub::getAuthSubTokenUri($next,
  58.                                                   $scope,
  59.                                                   $secure,
  60.                                                   $session);
  61. }
  62.  
  63. /**
  64. * Retourne un objet servant de client HTTP avec les bons en-têtes,
  65. * permettant de communiquer avec les services Google, et utilisant
  66. * l'authentification AuthSub.
  67. *
  68. * Utilise $_SESSION['sessionToken'] pour stocker le jeton de session
  69. * AuthSub après l'avoir obtenu. $_GET['token'] récupère ce jeton
  70. * après la redirection d'authentification
  71. *
  72. * @return Zend_Http_Client
  73. */
  74. function getAuthSubHttpClient()
  75. {
  76.     global $_SESSION, $_GET;
  77.     if (!isset($_SESSION['sessionToken']) && isset($_GET['token'])) {
  78.         $_SESSION['sessionToken'] =
  79.             Zend_Gdata_AuthSub::getAuthSubSessionToken($_GET['token']);
  80.     }
  81.     $client =
  82.         Zend_Gdata_AuthSub::getHttpClient($_SESSION['sessionToken']);
  83.     return $client;
  84. }
  85.  
  86. /**
  87. * Créer une instance du service, redirigeant l'utilisateur
  88. * vers le serveur AuthSub si nécéssaire.
  89. */
  90. $service = new Zend_Gdata_Photos(getAuthSubHttpClient());

Enfin, un client non authentifié peut aussi être crée :

  1. // Création d'une instance du service en mode non authentifié
  2. $service = new Zend_Gdata_Photos();

Comprendre et construire des requêtes

Pour créer des requêtes vers le service Web, vous devrez utiliser une de ces classes :

  • User Cette classe requêtera tout ce qui concerne un utilisateur du service. Sans spécifier d'utilisateur, "default" sera utilisé.

  • Album Cette classe va servir de base pour toutes les requêtes concernant les albums Picasa.

  • Photo Cette classe va servir de base pour toutes les requêtes concernant les photos Picasa.

Une UserQuery peut être construite comme suit :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_UserQuery();
  6. $query->setUser("sample.user");

Pour chaque requête, des paramètres de limitations de la recherche peuvent être passés grâce aux méthodes get(Paramètre) and set(Paramètre) :

  • Projection spécifie le format de retour des données dans le flux. Peut être "api" ou "base". En temps normal, "api" est conseillé, c'est la valeur par défaut d'ailleurs.

  • Type détermine le type des éléments retournés, "feed"(défaut) ou "entry".

  • Access détermine la visibilité des éléments retournés, "all"(défaut), "public", ou "private". Les éléments non publics ne seront retournés que si le client est authentifié.

  • Tag fournit un filtre par mots-clés sur les éléments retournés.

  • Kind détermine un filtre sur la sorte (le type) d'éléments retournés.

  • ImgMax spécifie un filtre par dimension maximale sur les éléments retournés.

  • Thumbsize spécifie un filtre par dimension maximale des miniatures retournées.

  • User spécifie l'utilisateur dont les éléments sont recherchés. Par défaut, "default".

  • AlbumId spécifie l'identifiant de l'album recherché. Ceci ne s'applique qu'aux requêtes album et photo. Dans le cas d'une recherche de photo, ceci indique l'album dans lequel effectuer la requête de recherche. Ce paramètre annule et remplace AlbumName, si spécifié.

  • AlbumName spécifie le nom de l'album recherché. Ceci ne s'applique qu'aux requêtes album et photo. Dans le cas d'une recherche de photo, ceci indique l'album dans lequel effectuer la requête de recherche. Ce paramètre annule et remplace AlbumId, si spécifié.

  • PhotoId spécifie l'identifiant de la photo recherchée. Ceci ne s'applique qu'aux requêtes photo.

Récupérer des flux et des éléments

Le service propose des méthodes de récupération de flux, ou d'éléments simples, concernant les utilisateurs, albums, ou photos.

Récupérer un utilisateur

Le service propose de récupérer un utilisateur, et toutes les infos de son flux, comme ses photos, ses albums.... Si le client est authentifié et demande des informations sur son propre compte, alors les éléments marqués comme "hidden" seront aussi retournés.

Le flux de l'utilisateur est accessible en passant son nom à la méthode getUserFeed :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. try {
  6.     $userFeed = $service->getUserFeed("sample.user");
  7. } catch (Zend_Gdata_App_Exception $e) {
  8.     echo "Error: " . $e->getMessage();
  9. }

Ou alors, le flux peut être requêté directement :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_UserQuery();
  6. $query->setUser("sample.user");
  7.  
  8. try {
  9.     $userFeed = $service->getUserFeed(null, $query);
  10. } catch (Zend_Gdata_App_Exception $e) {
  11.     echo "Error: " . $e->getMessage();
  12. }

Construire une requête donne aussi accès aux éléments d'un utilisateur :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_UserQuery();
  6. $query->setUser("sample.user");
  7. $query->setType("entry");
  8.  
  9. try {
  10.     $userEntry = $service->getUserEntry($query);
  11. } catch (Zend_Gdata_App_Exception $e) {
  12.     echo "Error: " . $e->getMessage();
  13. }

Récupérer un album

Le service donne accès aux flux d'albums et à leurs contenus.

Le flux d'albums est disponible en construisant un objet de requête et en le passant à getAlbumFeed :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_AlbumQuery();
  6. $query->setUser("sample.user");
  7. $query->setAlbumId("1");
  8.  
  9. try {
  10.     $albumFeed = $service->getAlbumFeed($query);
  11. } catch (Zend_Gdata_App_Exception $e) {
  12.     echo "Error: " . $e->getMessage();
  13. }

L'objet de requête accepte aussi un nom d'album avec setAlbumName. Attention, ceci annule un identifiant d'album éventuellement précédemment spécifié.

Construire une requête donne aussi accès au requêtage d'un album :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_AlbumQuery();
  6. $query->setUser("sample.user");
  7. $query->setAlbumId("1");
  8. $query->setType("entry");
  9.  
  10. try {
  11.     $albumEntry = $service->getAlbumEntry($query);
  12. } catch (Zend_Gdata_App_Exception $e) {
  13.     echo "Error: " . $e->getMessage();
  14. }

Récupérer une Photo

Le service permet la récupération de flux de photos, et des commentaires et/ou mots-clés associés

Le flux de photos est accessible en construisant un objet de requête et en le passant à la méthode getPhotoFeed :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_PhotoQuery();
  6. $query->setUser("sample.user");
  7. $query->setAlbumId("1");
  8. $query->setPhotoId("100");
  9.  
  10. try {
  11.     $photoFeed = $service->getPhotoFeed($query);
  12. } catch (Zend_Gdata_App_Exception $e) {
  13.     echo "Error: " . $e->getMessage();
  14. }

Construire une requête donne aussi accès au requêtage d'une photo :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_PhotoQuery();
  6. $query->setUser("sample.user");
  7. $query->setAlbumId("1");
  8. $query->setPhotoId("100");
  9. $query->setType("entry");
  10.  
  11. try {
  12.     $photoEntry = $service->getPhotoEntry($query);
  13. } catch (Zend_Gdata_App_Exception $e) {
  14.     echo "Error: " . $e->getMessage();
  15. }

Récupérer des commentaires

Vous pouvez récupérer des commentaires depuis des éléments divers de flux. En spécifiant à votre requête un paramètre de "comment", celle-ci retournera les mots-clés associés à la ressource demandée (user, album ou photo)

Voici comment effectuer des actions sur les commentaires récupérés d'une photo :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_PhotoQuery();
  6. $query->setUser("sample.user");
  7. $query->setAlbumId("1");
  8. $query->setPhotoId("100");
  9. $query->setKind("comment");
  10.  
  11. try {
  12.     $photoFeed = $service->getPhotoFeed($query);
  13.  
  14.     foreach ($photoFeed as $entry) {
  15.         if ($entry instanceof Zend_Gdata_Photos_CommentEntry) {
  16.             // Faites quelque chose avec le commentaire
  17.         }
  18.     }
  19. } catch (Zend_Gdata_App_Exception $e) {
  20.     echo "Error: " . $e->getMessage();
  21. }

Récupérer des mots-clés

Vous pouvez récupérer des mots-clés depuis des éléments divers de flux. En spécifiant à votre requête un paramètre de "tag", celle-ci retournera les mots-clés associés à la ressource demandée.

Voici comment effectuer des actions sur les mots-clés récupérés d'une photo :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $query = new Zend_Gdata_Photos_PhotoQuery();
  6. $query->setUser("sample.user");
  7. $query->setAlbumId("1");
  8. $query->setPhotoId("100");
  9. $query->setKind("tag");
  10.  
  11. try {
  12.     $photoFeed = $service->getPhotoFeed($query);
  13.  
  14.     foreach ($photoFeed as $entry) {
  15.         if ($entry instanceof Zend_Gdata_Photos_TagEntry) {
  16.             // Faites quelque chose avec le mot-clé
  17.         }
  18.     }
  19. } catch (Zend_Gdata_App_Exception $e) {
  20.     echo "Error: " . $e->getMessage();
  21. }

Créer des ressources

Des opérations de création sont possible, qu'il s'agisse d'albums, photos, commentaires, ou mots-clés.

Créer un album

Il est possible de créer un album, pour les clients authentifiés :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $entry = new Zend_Gdata_Photos_AlbumEntry();
  6. $entry->setTitle($service->newTitle("test album"));
  7.  
  8. $service->insertAlbumEntry($entry);

Créer une photo

Créer une photo est possible pour les clients authentifiés, procédez comme suit :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. // $photo est le nom d'un fichier issu d'un formulaire d'uplaod
  6.  
  7. $fd = $service->newMediaFileSource($photo["tmp_name"]);
  8. $fd->setContentType($photo["type"]);
  9.  
  10. $entry = new Zend_Gdata_Photos_PhotoEntry();
  11. $entry->setMediaSource($fd);
  12. $entry->setTitle($service->newTitle($photo["name"]));
  13.  
  14. $albumQuery = new Zend_Gdata_Photos_AlbumQuery;
  15. $albumQuery->setUser("sample.user");
  16. $albumQuery->setAlbumId("1");
  17.  
  18. $albumEntry = $service->getAlbumEntry($albumQuery);
  19.  
  20. $service->insertPhotoEntry($entry, $albumEntry);

Créer un commentaire pour une photo

Il est possible de créer un commentaire pour une photo, voici un exemple :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $entry = new Zend_Gdata_Photos_CommentEntry();
  6. $entry->setTitle($service->newTitle("comment"));
  7. $entry->setContent($service->newContent("comment"));
  8.  
  9. $photoQuery = new Zend_Gdata_Photos_PhotoQuery;
  10. $photoQuery->setUser("sample.user");
  11. $photoQuery->setAlbumId("1");
  12. $photoQuery->setPhotoId("100");
  13. $photoQuery->setType('entry');
  14.  
  15. $photoEntry = $service->getPhotoEntry($photoQuery);
  16.  
  17. $service->insertCommentEntry($entry, $photoEntry);

Créer un mot-clé pour une photo

Il est possible de créer un mot-clé pour une photo, voici un exemple :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $entry = new Zend_Gdata_Photos_TagEntry();
  6. $entry->setTitle($service->newTitle("tag"));
  7.  
  8. $photoQuery = new Zend_Gdata_Photos_PhotoQuery;
  9. $photoQuery->setUser("sample.user");
  10. $photoQuery->setAlbumId("1");
  11. $photoQuery->setPhotoId("100");
  12. $photoQuery->setType('entry');
  13.  
  14. $photoEntry = $service->getPhotoEntry($photoQuery);
  15.  
  16. $service->insertTagEntry($entry, $photoEntry);

Supprimer des éléments

Il est possible de supprimer albums, photos, commentaires, et mots-clés.

Supprimer un album

Supprimer un album est possible si le client est authentifié :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $albumQuery = new Zend_Gdata_Photos_AlbumQuery;
  6. $albumQuery->setUser("sample.user");
  7. $albumQuery->setAlbumId("1");
  8. $albumQuery->setType('entry');
  9.  
  10. $entry = $service->getAlbumEntry($albumQuery);
  11.  
  12. $service->deleteAlbumEntry($entry, true);

Supprimer une photo

Supprimer une photo est possible si le client est authentifié :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $photoQuery = new Zend_Gdata_Photos_PhotoQuery;
  6. $photoQuery->setUser("sample.user");
  7. $photoQuery->setAlbumId("1");
  8. $photoQuery->setPhotoId("100");
  9. $photoQuery->setType('entry');
  10.  
  11. $entry = $service->getPhotoEntry($photoQuery);
  12.  
  13. $service->deletePhotoEntry($entry, true);

Supprimer un commentaire

Supprimer un commentaire est possible si le client est authentifié :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $photoQuery = new Zend_Gdata_Photos_PhotoQuery;
  6. $photoQuery->setUser("sample.user");
  7. $photoQuery->setAlbumId("1");
  8. $photoQuery->setPhotoId("100");
  9. $photoQuery->setType('entry');
  10.  
  11. $path = $photoQuery->getQueryUrl() . '/commentid/' . "1000";
  12.  
  13. $entry = $service->getCommentEntry($path);
  14.  
  15. $service->deleteCommentEntry($entry, true);

Supprimer un mot-clé

Supprimer un mot-clé est possible, si le client est authentifié :

  1. $service = Zend_Gdata_Photos::AUTH_SERVICE_NAME;
  2. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  3. $service = new Zend_Gdata_Photos($client);
  4.  
  5. $photoQuery = new Zend_Gdata_Photos_PhotoQuery;
  6. $photoQuery->setUser("sample.user");
  7. $photoQuery->setAlbumId("1");
  8. $photoQuery->setPhotoId("100");
  9. $photoQuery->setKind("tag");
  10. $query = $photoQuery->getQueryUrl();
  11.  
  12. $photoFeed = $service->getPhotoFeed($query);
  13.  
  14. foreach ($photoFeed as $entry) {
  15.     if ($entry instanceof Zend_Gdata_Photos_TagEntry) {
  16.         if ($entry->getContent() == $tagContent) {
  17.             $tagEntry = $entry;
  18.         }
  19.     }
  20. }
  21.  
  22. $service->deleteTagEntry($tagEntry, true);

Gestion des accès concurrents

Les flux GData, dont ceux de Picasa Web Albums, implémentent un système d'accès concurrent qui empêche les changements avec écrasements par inadvertance. Si vous demandez l'effacement d'une ressource qui a été modifiée depuis votre dernière requête, alors une exception sera levée, sauf si vous demandez le contraire explicitement (dans un tel cas, la procédure d'effacement sera réessayée sur l'élément mis à jour).

Voici un exemple de gestion des versions et accès concurrent sur un effacement avec deleteAlbumEntry:

  1. // $album est l'albumEntry à effacer
  2. try {
  3.     $this->delete($album);
  4. } catch (Zend_Gdata_App_HttpException $e) {
  5.     if ($e->getMessage()->getStatus() === 409) {
  6.         $entry =
  7.             new Zend_Gdata_Photos_AlbumEntry($e->getMessage()
  8.                                                ->getBody());
  9.         $this->delete($entry->getLink('edit')->href);
  10.     } else {
  11.         throw $e;
  12.     }
  13. }

Using Google Base