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. 'œ' |
$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; |
} |
|
} |
?> |