Subversion Repositories Applications.wikini

Compare Revisions

No changes between revisions

Regard whitespace Rev 71 → Rev 72

/branches/v1.0-pithivier/api/scripts/modules/migration_smart_flore/MigrationSmartFlore.php
14,25 → 14,106
 
protected $mode_verbeux = false;
// Paramêtres autorisées lors de l'appel au script en ligne de commande
protected $parametres_autorises = array(
'-n' => array(true, true, 'Nom du fichier ou du dossier à traiter'));
public function executer() {
// L'obligation de mettre un paramètre -a donnée par le framework
// n'a pas de sens, ça ne doit pas être obligatoire !!!
$cmd = $this->getParametre('a');
$this->mode_verbeux = $this->getParametre('v');
switch($cmd) {
case 'tous' :
case 'migrerFormatSmartFlore' :
$this->migrerFormatSmartFlore();
break;
case 'migrerSentiersSmartFlore' :
$this->migrerSentiersSmartFlore();
break;
default:
}
}
protected function migrerSentiersSmartFlore() {
$this->wiki = Registre::get('wikiApi');
$requete = 'SELECT * FROM '.$this->wiki->GetConfigValue('table_prefix').'pages WHERE latest = "Y" '.
'AND tag = "AccesProjet" ';
$page_sentiers = $this->wiki->LoadSingle($requete);
// Attention les wiki sont en iso Argh%#[{!?
// Il faut convertir car sinon certains sentiers ne matcheront pas à leur propriétaire
$page_sentiers['body'] = mb_convert_encoding($page_sentiers['body'], Config::get('encodage_appli'), Config::get('encodage_wiki'));
preg_match_all("|\[\[([^\]\]]*)\]\]|", $page_sentiers['body'], $sentiers, PREG_PATTERN_ORDER);
// Seule une partie du tableau contenant les noms des sentiers nous interesse
$sentiers = $sentiers[1];
echo "Nombre de sentiers à migrer : ".count($sentiers)."\n";
$valeurs_sentiers_a_inserer = array();
$proprietaires_sentiers = array();
// Chargement du fichier contenant les propriétaires à associer aux sentiers
$fichier = file(realpath(dirname(__FILE__)).'/proprietaires_sentiers.csv');
foreach ($fichier as $ligne) {
$data = str_getcsv($ligne);
if($data[2] != "") {
// on associe un titre de sentier à un email (la clé est le titre de sentier)
$proprietaires_sentiers[trim($data[0])] = trim($data[2]);
}
}
$courriel_proprietaires = array_values(array_unique($proprietaires_sentiers));
// Chargement des infos des utilisateurs pour obtenirs leurs nomWikis associés
$url_infos_courriels = Config::get('annuaire_infos_courriels_url').implode(',', $courriel_proprietaires);
$infos_proprietaires = json_decode(file_get_contents($url_infos_courriels), true);
$infos_proprietaires_a_sentier = array();
foreach($proprietaires_sentiers as $nom_sentier => $proprietaire_sentier) {
if(isset($infos_proprietaires[$proprietaire_sentier])) {
$infos_proprietaires_a_sentier[$nom_sentier] = $infos_proprietaires[$proprietaire_sentier]['nomWiki'];
} else {
// les sentiers sans propriétaires sont affectés au compte accueil
$infos_proprietaires_a_sentier[$nom_sentier] = "AssociationTelaBotanica";
}
}
$requete_insertion = 'INSERT INTO '.$this->wiki->GetConfigValue('table_prefix').'triples '.
'(resource, property, value) VALUES ';
foreach($sentiers as $sentier) {
list($tag, $titre) = explode(' ', $sentier, 2);
// Reconversion dans l'encodage du wiki pour l'insertion
$titre_encode_wiki = mb_convert_encoding($titre, Config::get('encodage_wiki'), Config::get('encodage_appli'));
$requete = 'SELECT * FROM '.$this->wiki->GetConfigValue('table_prefix').'pages WHERE latest = "Y" '.
'AND tag = "'.$tag.'" ';
$infos_sentier = $this->wiki->LoadSingle($requete);
$proprietaire = !empty($infos_proprietaires_a_sentier[$titre]) ? $infos_proprietaires_a_sentier[$titre] : "AssociationTelaBotanica";
$valeurs_sentiers_a_inserer[] = "('".addslashes(trim($titre_encode_wiki))."', 'smartFlore.sentiers', '".$proprietaire."')";
// Recherche de toutes les fiches contenues dans le sentier (normalement sous forme de liens vers des fiches de type
// SmartFloreYYYntZZZ où YYY est un code de référentiel et ZZZ un numéro taxonomique)
preg_match_all("|\[\[(SmartFlore[^(?:nt)]*nt[0-9]*)|", $infos_sentier['body'], $fiches_du_sentier, PREG_PATTERN_ORDER);
if(!empty($fiches_du_sentier[0])) {
foreach($fiches_du_sentier[1] as $fiche_du_sentier) {
$valeurs_fiches_a_associer[] = "('".$fiche_du_sentier."', 'smartFlore.sentiers.fiche', '".addslashes(trim($titre_encode_wiki))."')";
}
}
}
$valeurs_a_inserer = $valeurs_sentiers_a_inserer + $valeurs_fiches_a_associer;
$requete_insertion .= implode(', '."\n", $valeurs_a_inserer);
// Tout est contenu dans la table triple du wiki, donc une seule requête suffit pour tout insérer
$this->wiki->Query($requete_insertion);
echo 'Migration des sentiers effectuée'."\n";
exit;
}
protected function migrerFormatSmartFlore() {
 
// sections "souples" - attention, ne seront pas "quotées" mais interprétées comme morceaux de regexp directement !
/branches/v1.0-pithivier/api/scripts/modules/migration_smart_flore/proprietaires_sentiers.csv
New file
0,0 → 1,30
Sentier de Bavay par le CPIE Bocage de l'Avesnois,Jean-Baptiste Lefevre,jb.lefevre@hotmail.fr
Sentier du parc du Banco à Abidjan,François Malan,malandfrancois@yahoo.fr
Sentier atelier bleu cap,Clélia eychenne,c.eychenne@atelierbleu.fr
Sentier DAL Jean Moulin,?,
Sentier Parc du CNRST,Paulin Koura,pkoura@hotmail.com
Sentier Afrique Tropicale,Tela ,accueil@tela-botanica.org
Jardin Botanique de Montpellier,Didier Morisot ,dmorisot@yahoo.fr
Arbres Remarquables,Tela ,accueil@tela-botanica.org
Familles Botaniques,Tela ,accueil@tela-botanica.org
Jardin Botanique Alpin,Tela ,accueil@tela-botanica.org
Sentier d'interprétation de Lirac,"Wiki modifié par Adeline, Thibaut et c23394f1.fsp.oleane.fr",
Sauvage de ma rue,Tela ,accueil@tela-botanica.org
Observatoire des Saisons,Tela ,accueil@tela-botanica.org
Sentier botanique Fête de la Nature,Tela ,accueil@tela-botanica.org
Parcours CFA Montpellier,Tela ,accueil@tela-botanica.org
Opération libre à Gerardmer,Tela ,accueil@tela-botanica.org
Sentier temporaire au Domaine du Soucy,Adeline Tonnin,a.tonnin@cc-paysdelimours.fr
Sentier du LEGTA de Vendôme,Alexis Villeneuve,alexis.villeneuve@gmail.com
Sentier du Gîte de La Biolette,Danielle Daurelle,gite@biolette.com
Sentier Les restanques Le Loup,Virginie Bueil,
Sentier botanique du Vieux Sahune,Vincent Aubert,vaubert@baronnies-provencales.fr
Chemin de Béost à Bagès : Cami Vielh,Dany Roussel,dany.roussel4@orange.fr
Le Grand Mas sentier botanique du Grand Mas,Olivier Lemaire,olperso@gmail.com
Sentier Botanique de Teyran,Monique Mirès,moniquemires@free.fr
Exposition de Tela,Tela ,accueil@tela-botanica.org
Sentier de Clavary-Valcluse,Louis Amandier,louis.amandier@gmail.com
Sentier de la Formation Sauvages au CNFPT Montpellier,Tela ,accueil@tela-botanica.org
Sentier Festi'Seounes,François Marsick,francois.marsick@free.fr
Sauvages et ODS complétées,Tela ,accueil@tela-botanica.org
Espèces des Mission Flore,Tela ,accueil@tela-botanica.org
/branches/v1.0-pithivier/.
Property changes:
Added: svn:mergeinfo
Merged /trunk:r69-70