Subversion Repositories Applications.wikini

Compare Revisions

No changes between revisions

Ignore whitespace Rev 73 → Rev 74

/branches/v1.0-pithivier/api/scripts/modules/migration_smart_flore/MigrationSmartFlore.php
23,8 → 23,8
$this->migrerFormatSmartFlore();
break;
case 'migrerSentiersSmartFlore' :
$this->migrerSentiersSmartFlore();
case 'migrerSentiersSmartFlore' :
$this->migrerSentiersSmartFlore();
break;
default:
32,19 → 32,19
}
protected function migrerSentiersSmartFlore() {
$this->wiki = Registre::get('wikiApi');
$requete = 'SELECT * FROM '.$this->wiki->GetConfigValue('table_prefix').'pages WHERE latest = "Y" '.
$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
// 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();
51,12 → 51,12
$proprietaires_sentiers = array();
// Chargement du fichier contenant les propriétaires à associer aux sentiers
$fichier = file(realpath(dirname(__FILE__)).'/proprietaires_sentiers.csv');
$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)
// on associe un titre de sentier à un email (la clé est le titre de sentier)
$proprietaires_sentiers[trim($data[0])] = trim($data[2]);
}
}
81,14 → 81,15
'(resource, property, value) VALUES ';
foreach($sentiers as $sentier) {
list($tag, $titre) = explode(' ', $sentier, 2);
// Reconversion dans l'encodage du wiki pour l'insertion
 
list($tag, $titre) = explode(' ', $sentier, 2);
$titre = trim($titre);
// 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.'" ';
$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";
105,7 → 106,7
}
}
$valeurs_a_inserer = $valeurs_sentiers_a_inserer + $valeurs_fiches_a_associer;
$valeurs_a_inserer = array_merge($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);
118,7 → 119,7
 
// sections "souples" - attention, ne seront pas "quotées" mais interprétées comme morceaux de regexp directement !
$sections = array("Fiche simplifi.+e Smart.+flore", "Introduction","Comment la reconna.+tre.+","Son histoire","Ses usages",".+(?:cologie|habitat).+","Ce qu.+il faut savoir.+","Sources");
$nouvelles_sections = array(
$nouvelles_sections = array(
"Description" => array("Introduction","Comment la reconna.+tre.+","Son histoire"),
"Usages" => array("Ses usages", "Ce qu.+il faut savoir.+"),
"Écologie & habitat" => array(".+(?:cologie|habitat).+"), // groupe non-capturant avec (?:a|b)
184,8 → 185,8
}
// http://stackoverflow.com/questions/834303/startswith-and-endswith-functions-in-php
protected function endsWith($haystack, $needle) {
// search forward starting from end minus needle length characters
return $needle === "" || (($temp = strlen($haystack) - strlen($needle)) >= 0 && strpos($haystack, $needle, $temp) !== FALSE);
protected function endsWith($haystack, $needle) {
// search forward starting from end minus needle length characters
return $needle === "" || (($temp = strlen($haystack) - strlen($needle)) >= 0 && strpos($haystack, $needle, $temp) !== FALSE);
}
}
/branches/v1.0-pithivier
Property changes:
Modified: svn:mergeinfo
Merged /trunk:r73