Subversion Repositories eFlore/Applications.del

Compare Revisions

Ignore whitespace Rev 1435 → Rev 1436

/trunk/services/modules/0.1/motscles/MotClePictoflora.php
New file
0,0 → 1,37
<?php
/**
* @author Raphaël Droz <raphael@tela-botanica.org>
* @author Aurélien PERONNET <aurelien@tela-botanica.org>
* @copyright Copyright (c) 2013, Tela Botanica (accueil@tela-botanica.org)
* @license Licence CECILL http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt
* @license Licence GNU-GPL http://www.gnu.org/licenses/gpl.html
* @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
*/
class MotClePictoflora {
 
// cf: images/VotesImage.php
static function updateStats($db, $id_image) {
$id_image = intval($id_image);
if(!$id_image) throw new Exception("Ne peut mettre à jour les statistiques de vote",
RestServeur::HTTP_CODE_ERREUR);
 
// on utilise toujours cette table de stats (ListeImages) pour les mots-clef "actif".
$db->requeter(sprintf('UPDATE del_image_stat SET nb_tags = (select COUNT(id_tag) FROM del_image_tag WHERE ce_image = %1$d AND actif = 1) WHERE ce_image = %1$d', $id_image));
}
 
//TODO: déplacer les fonctions ci dessus et dessous dans une classe
// utilitaire
static function normaliserMotCle($str, $charset='utf-8') {
$str = htmlentities($str, ENT_NOQUOTES, $charset);
$str = preg_replace('#&([A-za-z])(?:acute|cedil|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
// supprime les espaces, tirets et simple-quotes en underscores
return str_replace(array(" ", "-", "'"),
array('_', '_', '_'),
$str);
return mb_strtolower($str);
}
}
/trunk/services/modules/0.1/motscles/SupprimerMotCle.php
14,6 → 14,8
* @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
*/
 
require_once('MotClePictoflora.php');
 
class SupprimerMotCle {
private $conteneur;
91,18 → 93,17
* @param $id_mot_cle string identifiant de mot clé
* */
private function supprimerMotCle($id_mot_cle) {
$valeurs_a_supprimer = '';
$requete = 'UPDATE del_image_tag '.
'SET actif = 0, date_modification = NOW() '.
'WHERE id_tag ='.$this->bdd->proteger($id_mot_cle);
$retour = $this->bdd->requeter(sprintf('UPDATE del_image_tag '.
'SET actif = 0, date_modification = NOW() '.
'WHERE id_tag = %d',
intval($id_mot_cle)));
 
$retour = $this->bdd->requeter($requete);
if ($retour == null) {
$e = 'Erreur inopinée lors de la suppression';
throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
}
 
MotClePictoflora::updateStats($this->bdd, $id_mot_cle);
return null;
}
}
/trunk/services/modules/0.1/motscles/AjouterMotCle.php
14,6 → 14,8
* @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
*/
 
require_once('MotClePictoflora.php');
 
class AjouterMotCle {
private $conteneur;
99,60 → 101,34
* @param $mot_cle array la liste des paramètres
* */
private function insererMotCle($mot_cle) {
$valeurs_a_inserer = '';
$mots_cles = $this->traiterMotsClesMultiples($mot_cle['mot_cle']);
$id_image = intval($mot_cle['image']);
$id_auteur = $mot_cle['auteur.id'];
$mots_cles = explode(",", $mot_cle['mot_cle']);
array_walk($mots_cles, create_function('&$val', '$val = trim($val);'));
 
$valeurs_a_inserer = array();
foreach ($mots_cles as $mot_cle_a_inserer) {
$mot_cle_normalise = $this->normaliserMotCle($mot_cle_a_inserer);
$valeurs_a_inserer .= '('.$this->bdd->proteger($mot_cle['image']).','.
$this->bdd->proteger($mot_cle['auteur.id']).', '.
$this->bdd->proteger(trim($mot_cle_a_inserer)).', '.
$this->bdd->proteger($mot_cle_normalise).', '.
'NOW(), '.
'1, '.
'NOW() '.
'), ';
$mot_cle_normalise = MotClePictoflora::normaliserMotCle($mot_cle_a_inserer);
$valeurs_a_inserer[] = sprintf('(%d, %s, %s, %s, NOW(), 1, NOW())',
$id_image,
$this->bdd->proteger($id_auteur),
$this->bdd->proteger(trim($mot_cle_a_inserer)),
$this->bdd->proteger($mot_cle_normalise));
}
$valeurs_a_inserer = rtrim($valeurs_a_inserer,', ');
$requete = 'INSERT INTO del_image_tag '.
'(ce_image, ce_utilisateur, tag, tag_normalise, date, actif, date_modification) '.
'VALUES '.$valeurs_a_inserer;
 
$retour = $this->bdd->requeter($requete);
$retour = $this->bdd->requeter(sprintf(
'INSERT INTO del_image_tag (ce_image, ce_utilisateur, tag, tag_normalise, date, actif, date_modification) VALUES %s ',
implode(",", $valeurs_a_inserer)));
 
if ($retour == null) {
$e = 'Erreur inopinée lors de l\insertion';
throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
}
 
MotClePictoflora::updateStats($this->bdd, $mot_cle['image']);
//TODO: voir si cela a vraiment du sens lors de l'ajout de plusieurs mots clés
return null;
}
function traiterMotsClesMultiples($valeur_mot_cles) {
$tab_mots_cles = explode(",", $valeur_mot_cles);
return $tab_mots_cles;
}
private function normaliserMotCle($mot_cle) {
return mb_strtolower($this->supprimerAccents(trim($mot_cle)));
}
//TODO: déplacer les fonctions ci dessus et dessous dans une classe
// utilitaire
private function supprimerAccents($str, $charset='utf-8')
{
$str = htmlentities($str, ENT_NOQUOTES, $charset);
$str = preg_replace('#&([A-za-z])(?:acute|cedil|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
$str = str_replace(' ', '_', $str); // supprime les espaces en les remplaçant des underscores
$str = str_replace('-', '_', $str); // supprime les tirets en les remplaçant des underscores
$str = str_replace("'", '_', $str); // supprime les quotes en les remplaçant des underscores
return $str;
}
 
}
?>