La syntaxe intuitive de Zend_Feed
peut aussi bien servir à
lire des flux ou des entrées qu'à les construire et les modifier. Vous
pouvez facilement transformer vos nouveaux objets (ou objets modifiés)
en code XML bien formé et enregistrer ensuite ce code dans un fichier ou
le renvoyer au serveur.
Exemple 4.5. Modifier l'entrée existante d'un flux
<?php $flux = new Zend_Feed_Atom('http://atom.exemple.com/flux/1'); $entree = $flux->current(); $entree->title = 'Ceci est un nouveau titre'; $entree->author->email = '[email protected]'; echo $entree->saveXML(); ?>
Ce code affichera une représentation XML complète (y compris le
prologue <?xml ...>
) de la nouvelle entrée, avec les
espaces de noms XML nécessaires.
Notez que le code ci-dessus fonctionnera même si l'entrée existante
ne possédait pas de balise author
. Vous pouvez utiliser
autant de fois que vous le souhaitez l'opérateur d'accès
->
dans une instruction d'affectation; si nécessaire,
les niveaux intermédiaires seront créés pour vous automatiquement.
Si vous souhaitez utiliser dans votre entrée un espace de noms autre que
atom:
, rss:
ou osrss:
, vous devez
enregistrer cet espace de noms auprès de Zend_Feed
à l'aide
de la méthode Zend_Feed::registerNamespace()
. Lorsque vous
modifiez un élément existant, il gardera toujours son espace de noms
d'origine. Lorsque vous ajoutez un élément, il utilisera l'espace de
noms par défaut si vous ne spécifiez pas explicitement un autre espace
de noms.
Exemple 4.6. Créer une entrée Atom dont les éléments appartiennent à un espace de noms personnalisé
<?php $entree = new Zend_Feed_EntryAtom(); // en Atom, id est toujours affecté par le serveur $entree->title = 'mon entrée perso'; $entree->author->name = 'Auteur'; $entree->author->email = '[email protected]'; // maintenant on s'occupe de la partie personnalisée Zend_Feed::registerNamespace('monen', 'http://www.exemple.com/monen/1.0'); $entree->{'monen:monelement_un'} = 'ma première valeur personnalisée'; $entree->{'monen:conteneur_elt'}->partie1 = 'première partie imbriquée personnalisée'; $entree->{'monen:conteneur_elt'}->partie2 = 'deuxième partie imbriquée personnalisée'; echo $entree->saveXML(); ?>