Nettoyage du code et copie des scripts d'import
This commit is contained in:
parent
15bf26307e
commit
fcb6fb310e
@ -16,172 +16,6 @@ function filtre_libreavous_supp_numero($texte) {
|
||||
return trim(substr($texte, $idx +1));
|
||||
}
|
||||
|
||||
function balise_LIBREAVOUS_IMPORT($p) {
|
||||
$id_rubrique = "''";
|
||||
$id_secteur = "''";
|
||||
if (($v = interprete_argument_balise(1,$p))!==NULL){
|
||||
$id_rubrique = $v;
|
||||
if (($v = interprete_argument_balise(2,$p))!==NULL) {
|
||||
$id_secteur = $v;
|
||||
}
|
||||
}
|
||||
$p->code = "libreavous_Import()";
|
||||
return $p;
|
||||
}
|
||||
|
||||
function libreavous_Import_Historique() {
|
||||
$historique = simplexml_load_file ("/var/www/exemole.fr/libreavous/historique.xml");
|
||||
foreach ($historique->item as $item) {
|
||||
$code = $item['code'];
|
||||
$array = array(
|
||||
'drupal_guid' => $item['guid'],
|
||||
'drupal_pubdate' => $item['pubdate']
|
||||
);
|
||||
$type = $item['type'];
|
||||
if ($type == 'emission') {
|
||||
$existant = sql_select("id_article","spip_articles","podcast_code=".sql_quote($code));
|
||||
if ($existant and sql_count($existant)>0) {
|
||||
$r = sql_fetch($existant);
|
||||
$id_article = $r["id_article"];
|
||||
sql_updateq("spip_articles", $array, "id_article=".$id_article);
|
||||
} else {
|
||||
echo "Émission inconnue = $code<br>" ;
|
||||
}
|
||||
} else {
|
||||
$chapitreExistant = sql_select("id_chapitre","spip_chapitres",array("code_podcast=".sql_quote($code), "code_fichier=".sql_quote($item['chapitre'])));
|
||||
if ($chapitreExistant and sql_count($chapitreExistant)>0) {
|
||||
$r = sql_fetch($chapitreExistant);
|
||||
$id_chapitre = $r["id_chapitre"];
|
||||
sql_updateq("spip_chapitres", $array, "id_chapitre=".$id_chapitre);
|
||||
} else {
|
||||
echo "Chapitre inconnu = $code / fichier = ".$item['chapitre']."<br>" ;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function libreavous_Import($id_rubrique, $id_secteur) {
|
||||
$emissions = simplexml_load_file ("/var/www/exemole.fr/libreavous/verspip.xml");
|
||||
foreach ($emissions->emission as $emission) {
|
||||
$code = $emission["code"];
|
||||
$emissionArray = array(
|
||||
'lang' => 'fr',
|
||||
'surtitre' => $emission["numero"],
|
||||
'titre' => $emission["numero"].' - '.$emission["titre"],
|
||||
'soustitre' => "",
|
||||
'id_rubrique' => $id_rubrique,
|
||||
'id_secteur' => $id_secteur,
|
||||
'descriptif' => $emission["description"],
|
||||
'chapo' => $emission["programme"],
|
||||
'texte' => $emission["references"],
|
||||
'ps' => "",
|
||||
'statut' => 'publie',
|
||||
'accepter_forum' => 'non',
|
||||
'date' => libreavous_toDateIso($emission["code"]),
|
||||
'podcast_code' => $emission["code"],
|
||||
'podcast_duree' => $emission["duree"],
|
||||
'podcast_mp3' => $emission["mp3"],
|
||||
'podcast_ogg' => $emission["ogg"],
|
||||
'podcast_transcription' => $emission["transcription"],
|
||||
'podcast_personnes' => $emission["personnes"],
|
||||
'podcast_galeriephotos' => $emission["galeriephotos"],
|
||||
'podcast_musique' => $emission["musique"]
|
||||
);
|
||||
$existant = sql_select("id_article","spip_articles","podcast_code=".sql_quote($code));
|
||||
if ($existant and sql_count($existant)>0) {
|
||||
$r = sql_fetch($existant);
|
||||
$id_article = $r["id_article"];
|
||||
sql_updateq("spip_articles", $emissionArray, "id_article=".$id_article);
|
||||
} else {
|
||||
$id_article = sql_insertq("spip_articles", $emissionArray);
|
||||
}
|
||||
foreach ($emission->chapitre as $chapitre) {
|
||||
$code_chapitre = $chapitre["code"];
|
||||
$chapitreArray = array(
|
||||
'titre' => $chapitre["titre"],
|
||||
'code' => $chapitre["code"],
|
||||
'id_article' => $id_article,
|
||||
'code_fichier' => $chapitre["fichier"],
|
||||
'code_podcast' => $emission["code"],
|
||||
'debut' => $chapitre["debut"],
|
||||
'fin' => $chapitre["fin"],
|
||||
'type_sujet' => $chapitre["type"],
|
||||
'chronique' => $chapitre["chronique"],
|
||||
'mp3' => $chapitre["mp3"],
|
||||
'ogg' => $chapitre["ogg"],
|
||||
'references_sujet' => $chapitre["references"]
|
||||
);
|
||||
$chapitreExistant = sql_select("id_chapitre","spip_chapitres",array("id_article=".$id_article, "code=".sql_quote($code_chapitre)));
|
||||
if ($chapitreExistant and sql_count($chapitreExistant)>0) {
|
||||
$r = sql_fetch($chapitreExistant);
|
||||
$id_chapitre = $r["id_chapitre"];
|
||||
sql_updateq("spip_chapitres", $chapitreArray, "id_chapitre=".$id_chapitre);
|
||||
} else {
|
||||
$id_nouveau_chapitre = sql_insertq("spip_chapitres", $chapitreArray);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function libreavous_toDateIso($code) {
|
||||
$texte = substr($code, 0, 4)."-".substr($code,4,2)."-".substr($code,6,2)." 15:30:00";
|
||||
return $texte;
|
||||
}
|
||||
|
||||
function libreavous_conversionDrupal($shortdate) {
|
||||
$annee = substr($shortdate, 0, 4);
|
||||
$mois = substr($shortdate, 4, 2);
|
||||
$jour = substr($shortdate, 6, 2);
|
||||
if (substr($jour, 0, 1) == "0") {
|
||||
$jour = substr($jour, 1, 1);
|
||||
}
|
||||
return $jour."-".libreavous_conversionMoisDrupal($mois)."-".$annee;
|
||||
}
|
||||
|
||||
function libreavous_conversionMoisDrupal($mois) {
|
||||
switch($mois) {
|
||||
case "01":
|
||||
return "janvier";
|
||||
case "02":
|
||||
return "fevrier";
|
||||
case "03":
|
||||
return "mars";
|
||||
case "04":
|
||||
return "avril";
|
||||
case "05":
|
||||
return "mai";
|
||||
case "06":
|
||||
return "juin";
|
||||
case "07":
|
||||
return "juillet";
|
||||
case "08":
|
||||
return "aout";
|
||||
case "09":
|
||||
return "septembre";
|
||||
case "10":
|
||||
return "octobre";
|
||||
case "11":
|
||||
return "novembre";
|
||||
case "12":
|
||||
return "decembre";
|
||||
default:
|
||||
return "XX";
|
||||
}
|
||||
}
|
||||
|
||||
function libreavous_nomtypesujet($abbr) {
|
||||
switch($abbr) {
|
||||
case "CH":
|
||||
return "Chronique";
|
||||
case "SL":
|
||||
return "Sujet libre";
|
||||
case "AN":
|
||||
return "Annonce";
|
||||
default:
|
||||
return $abbr;
|
||||
}
|
||||
}
|
||||
|
||||
// plutot utiliser la fonction spip taille_en_octets
|
||||
function libreavous_mio($number) {
|
||||
@ -230,3 +64,213 @@ function libreavous_aveczerod($chaine) {
|
||||
return $chaineaveczero;
|
||||
}
|
||||
|
||||
|
||||
/***************************************
|
||||
* Importation du JSON des chapitres
|
||||
* et des autres informations (durée, taille, etc)
|
||||
***************************************/
|
||||
|
||||
function balise_LIBREAVOUS_IMPORT($p) {
|
||||
$id_article = "''";
|
||||
if (($v = interprete_argument_balise(1,$p))!==NULL){
|
||||
$id_article = $v;
|
||||
}
|
||||
$p->code = "libreavous_import_run($id_article)";
|
||||
return $p;
|
||||
}
|
||||
|
||||
function libreavous_import_run($id_article) {
|
||||
$id_article = intval($id_article);
|
||||
$existant = sql_select("podcast_code","spip_articles","id_article=".$id_article);
|
||||
if ($existant and sql_count($existant)>0) {
|
||||
$r = sql_fetch($existant);
|
||||
$code_emission = $r["podcast_code"];
|
||||
if(strlen($code_emission) == 0) {
|
||||
return "Le code de l'émission n'est pas renseigné";
|
||||
}
|
||||
} else {
|
||||
return "Émission inconnue = ".$id_article;
|
||||
}
|
||||
$erreurs = array();
|
||||
$json = false;
|
||||
$podcast_duree = "";
|
||||
$ogg_size = "";
|
||||
$mp3_size = "";
|
||||
try {
|
||||
$jsonContents = file_get_contents("https://forge.april.org/libreavous/lav-outils/src/branch/master/podcasts/config/lav-".$code_emission.".json");
|
||||
$json = json_decode($jsonContents, true);
|
||||
if (!$json) {
|
||||
$erreurs[] = "JSON incorrect";
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
$erreurs[] = $e->getMessage();
|
||||
}
|
||||
try {
|
||||
$podcast_duree = libreavous_import_getDuration($code_emission, null);
|
||||
} catch (Exception $e) {
|
||||
$erreurs[] = $e->getMessage();
|
||||
}
|
||||
try {
|
||||
$ogg_size = libreavous_import_getSize($code_emission, null, "ogg");
|
||||
} catch (Exception $e) {
|
||||
$erreurs[] = $e->getMessage();
|
||||
}
|
||||
try {
|
||||
$mp3_size = libreavous_import_getSize($code_emission, null, "mp3");
|
||||
} catch (Exception $e) {
|
||||
$erreurs[] = $e->getMessage();
|
||||
}
|
||||
$chapitres = array();
|
||||
if (array_key_exists("chapters", $json)) {
|
||||
$chapters = $json["chapters"];
|
||||
$count = count($chapters);
|
||||
if ($count > 0) {
|
||||
$duree_sujetlong = 30 * 60;
|
||||
$sujetlongIndex = -1;
|
||||
for($i = 0; $i < $count; $i++) {
|
||||
$chapter = $chapters[$i];
|
||||
$chapter["type"] = "";
|
||||
$debutSecondes = libreavous_import_toSeconde($chapter["start_timestamp"]);
|
||||
$finSecondes = libreavous_import_toSeconde($chapter["end_timestamp"]);
|
||||
if ($debutSecondes === false) {
|
||||
$erreurs[] = "start_timestamp incorrect : ".$chapter["start_timestamp"];
|
||||
} else if ($finSecondes === false) {
|
||||
$erreurs[] = "end_timestamp incorrect : ".$chapter["end_timestamp"];
|
||||
} else if ($debutSecondes == $finSecondes) {
|
||||
$erreurs[] = "start_timestamp et end_timestamp identiques : ".$chapter["end_timestamp"];
|
||||
} else {
|
||||
$duree = $finSecondes - $debutSecondes;
|
||||
if ($duree > $duree_sujetlong) {
|
||||
$sujetlongIndex = $i;
|
||||
$duree_sujetlong = $duree;
|
||||
}
|
||||
$chapter["duree"] = $duree;
|
||||
}
|
||||
|
||||
if (!array_key_exists("chapter_title", $chapter)) {
|
||||
$chapter["chapter_title"] = "";
|
||||
$erreurs[] = "Titre de chapitre manquant";
|
||||
}
|
||||
$chapter["ogg_size"] = "";
|
||||
$chapter["mp3_size"] = "";
|
||||
if (!array_key_exists("short_chapter_name", $chapter)) {
|
||||
$chapter["short_chapter_name"] = "";
|
||||
$erreurs[] = "Nom de fichier manquant";
|
||||
} else {
|
||||
try {
|
||||
$chapter["ogg_size"] = libreavous_import_getSize($code_emission, $chapter["short_chapter_name"], "ogg");
|
||||
} catch (Exception $e) {
|
||||
$erreurs[] = $e->getMessage();
|
||||
}
|
||||
try {
|
||||
$chapter["mp3_size"] = libreavous_import_getSize($code_emission, $chapter["short_chapter_name"], "mp3");
|
||||
} catch (Exception $e) {
|
||||
$erreurs[] = $e->getMessage();
|
||||
}
|
||||
}
|
||||
$chapter["chronique"]="";
|
||||
$chapitres[] = $chapter;
|
||||
}
|
||||
for($i = 0; $i < count($chapitres); $i++) {
|
||||
if ($i == $sujetlongIndex) {
|
||||
$chapitres[$i]["type"] = "SL";
|
||||
} else {
|
||||
$array = libreavous_import_checkType($chapitres[$i]);
|
||||
$chapitres[$i]["type"] = $array[0];
|
||||
if (count($array) > 1) {
|
||||
$chapitres[$i]["chronique"] = $array[1];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
$emissionArray = array(
|
||||
'podcast_duree' =>$podcast_duree,
|
||||
'podcast_mp3' => $mp3_size,
|
||||
'podcast_ogg' => $ogg_size
|
||||
);
|
||||
sql_updateq("spip_articles", $emissionArray, "id_article=".$id_article);
|
||||
foreach ($chapitres as $chapitre) {
|
||||
$code_chapitre = $chapitre["short_chapter_name"];
|
||||
$chapitreArray = array(
|
||||
'titre' => $chapitre["chapter_title"],
|
||||
'code' => $code_chapitre,
|
||||
'id_article' => $id_article,
|
||||
'code_fichier' => $chapitre["short_chapter_name"],
|
||||
'code_podcast' => $code_emission,
|
||||
'debut' => $chapitre["start_timestamp"],
|
||||
'fin' => $chapitre["end_timestamp"],
|
||||
'type_sujet' => $chapitre["type"],
|
||||
'chronique' => $chapitre["chronique"],
|
||||
'mp3' => $chapitre["mp3_size"],
|
||||
'ogg' => $chapitre["ogg_size"]
|
||||
);
|
||||
$chapitreExistant = sql_select("id_chapitre","spip_chapitres",array("id_article=".$id_article, "code=".sql_quote($code_chapitre)));
|
||||
if ($chapitreExistant and sql_count($chapitreExistant)>0) {
|
||||
$r = sql_fetch($chapitreExistant);
|
||||
$id_chapitre = $r["id_chapitre"];
|
||||
sql_updateq("spip_chapitres", $chapitreArray, "id_chapitre=".$id_chapitre);
|
||||
} else {
|
||||
$id_nouveau_chapitre = sql_insertq("spip_chapitres", $chapitreArray);
|
||||
}
|
||||
}
|
||||
$texteReponse = "Émission traitée : ". $code_emission;
|
||||
if (count($erreurs) > 0) {
|
||||
$texteReponse .= "<br><br>Erreurs : <br>".implode(" <br> ", $erreurs);
|
||||
}
|
||||
return $texteReponse;
|
||||
}
|
||||
|
||||
function libreavous_import_getDuration($code_emission, $code_sujet) {
|
||||
$fileName = "libre-a-vous-".$code_emission;
|
||||
if ($code_sujet) {
|
||||
$fileName .= "-".$code_sujet;
|
||||
}
|
||||
$fileName .= ".ogg.duration";
|
||||
return libreavous_import_getMediaFileContent($code_emission, $fileName);
|
||||
}
|
||||
|
||||
function libreavous_import_getSize($code_emission, $code_sujet, $extension) {
|
||||
$fileName = "libre-a-vous-".$code_emission;
|
||||
if ($code_sujet) {
|
||||
$fileName .= "-".$code_sujet;
|
||||
}
|
||||
$fileName .= ".".$extension.".size";
|
||||
return libreavous_import_getMediaFileContent($code_emission, $fileName);
|
||||
}
|
||||
|
||||
function libreavous_import_getMediaFileContent($code, $fileName) {
|
||||
$url = "https://media.april.org/audio/radio-cause-commune/libre-a-vous/emissions/".$code."/".$fileName;
|
||||
$contents = file_get_contents($url);
|
||||
$resultat = trim($contents);
|
||||
if (strlen($resultat) == 0) {
|
||||
throw new Exception("Fichier manquant ou vide : ".$url);
|
||||
}
|
||||
return $resultat;
|
||||
}
|
||||
|
||||
function libreavous_import_toSeconde($time) {
|
||||
$test = preg_match('/^(\d+):(\d+):(\d+)/', $time, $matches);
|
||||
if ($test !== false) {
|
||||
return ($matches[1] * 60 * 60) + ($matches[2] * 60) + ($matches[3]);
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function libreavous_import_checkType($chapitre) {
|
||||
$code = $chapitre["short_chapter_name"];
|
||||
$result = array();
|
||||
if ($code == "annonces") {
|
||||
$result[] = "AN";
|
||||
} else {
|
||||
$idx = strpos($code, "chronique-");
|
||||
if ($idx === 0) {
|
||||
$result[] = "CH";
|
||||
$nom_chronique = substr($code, strlen("chronique-"));
|
||||
} else {
|
||||
$result[] = "SC";
|
||||
}
|
||||
}
|
||||
return $result;
|
||||
}
|
||||
|
@ -1,14 +0,0 @@
|
||||
<BOUCLE_principale(RUBRIQUES) {id_rubrique}>
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>[(#TITRE|couper{80}|textebrut) - ][(#NOM_SITE_SPIP|textebrut)]</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
||||
</head>
|
||||
<body>
|
||||
<p>Importation vers : #TITRE</p>
|
||||
#LIBREAVOUS_IMPORT{#ID_RUBRIQUE,#ID_SECTEUR}
|
||||
</body>
|
||||
</html>
|
||||
</BOUCLE_principale>
|
9
squelettes/importjson.html
Normal file
9
squelettes/importjson.html
Normal file
@ -0,0 +1,9 @@
|
||||
<html lang="fr">
|
||||
<head>
|
||||
<title>Import</title>
|
||||
</head>
|
||||
<body>
|
||||
<p>
|
||||
#LIBREAVOUS_IMPORT{#ENV{id_article}}
|
||||
</body>
|
||||
</html>
|
Loading…
Reference in New Issue
Block a user