fonction API pour récupérer un alias d'un node ? [résolu]

Information importante

En raison d'un grand nombre d'inscriptions de spammers sur notre site, polluant sans relache notre forum, nous suspendons la création de compte via le formulaire de "sign up".

Il est néanmoins toujours possible de devenir adhérent•e en faisant la demande sur cette page, rubrique "Inscription" : https://www.drupal.fr/contact


De plus, le forum est désormais "interdit en écriture". Il n'est plus autorisé d'y écrire un sujet/billet/commentaire.

Pour contacter la communauté, merci de rejoindre le slack "drupalfrance".

Si vous voulez contacter le bureau de l'association, utilisez le formulaire disponible ici, ou envoyez-nous un DM sur twitter.

Bonjour à tous,

J'ai un problème que je n'arrive pas à résoudre. Je l'ai donc simplifié pour l'expliquer de manière claire. Je voudrais lister tous les billets de blog de tous les utilisateurs du site. J'ai configuré des patterns avec pathauto pour les billets de blog. Le pattern utilisé pour afficher un billet est blog/billet/[title] et tous les billets possèdent bien un alias. J'ai donc créé une vue qui affiche tous les billets de blog avec pour chacun un lien vers le node correspondant.

Voici le code de ma vue :

<?php
$result
= db_query("SELECT title FROM {node} WHERE type='blog'");

if (db_num_rows($result)) {

while ($obj=db_fetch_object($result)) {
$title = $obj->title;
echo
'<a href="'.base_path().'/blog/billet/'.$title.'">'.$title.'</a><br />';
}
}
?>

La question est comment, depuis un $title, retranscrire le lien tel qu'il est configuré dans pathauto. (avec toutes les règles définies concernant les accents, caractères spéciaux, etc)

pour ne pas avoir un lien du type:

<a href="xxx.com/blog/billet/test titre blog">test titre blog</a>,

qui mène vers une "page non trouvée", mais bien un lien de la forme

<a href="xxx.com/blog/billet/test-titre-blog">test titre blog</a>,

qui lui mène à la bonne page.

D'avance merci.

Version de Drupal : 

Perso j'utiliserai la fonction l qui permet de recuperer l'alias defini pour ton node
Donc en gros ca donnerai:

<?php
$result
= db_query("SELECT nid, title FROM {node} WHERE type='blog'");

if (
db_num_rows($result)) {
  while (
$obj=db_fetch_object($result)) {
    echo
l($obj->title, 'node/' . $obj->nid);
  }
}
?>