File "import_1_2.php"
Full path: /home/argothem/www/SpipFactory-fichiers_de_travail/sauvegarde-depannage-1.9a3.2/1.9/ecrire/inc/import_1_2.php
File size: 5.77 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/***************************************************************************\
* SPIP, Systeme de publication pour l'internet *
* *
* Copyright (c) 2001-2006 *
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
* *
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
\***************************************************************************/
if (!defined("_ECRIRE_INC_VERSION")) return;
// http://doc.spip.org/@description_table
function description_table($nom){
global $tables_principales, $tables_auxiliaires, $table_des_tables, $tables_des_serveurs_sql;
$nom_table = $nom;
if (in_array($nom, $table_des_tables))
$nom_table = 'spip_' . $nom;
include_spip('base/serial');
if (isset($tables_principales[$nom_table]))
return array($nom_table, $tables_principales[$nom_table]);
include_spip('base/auxiliaires');
$nom_table = 'spip_' . $nom;
if (isset($tables_auxiliaires[$nom_table]))
return array($nom_table, $tables_auxiliaires[$nom_table]);
if ($desc = spip_abstract_showtable($nom, '', true))
if (isset($desc['field'])) {
return array($nom, $desc);
}
return array($nom,array());
}
// pour le support des vieux dump
// http://doc.spip.org/@inc_import_1_2_dist
function inc_import_1_2_dist($f, $gz=false) {
global $import_ok, $abs_pos, $my_pos;
static $field_desc = array ();
// detruire les tables a restaurer
if (!$my_pos) import_init_tables();
static $tables;
if (!$tables) $tables = array(
'article' => 'spip_articles',
'auteur' => 'spip_auteurs',
'breve' => 'spip_breves',
'document' => 'spip_documents',
'forum' => 'spip_forum',
'groupe_mots' => 'spip_groupes_mots',
'message' => 'spip_messages',
'mot' => 'spip_mots',
'petition' => 'spip_petitions',
'rubrique' => 'spip_rubriques',
'signature' => 'spip_signatures',
'syndic' => 'spip_syndic',
'syndic_article' => 'spip_syndic_articles',
'type_document' => 'spip_types_documents'
);
$import_ok = false;
$b = '';
// Lire le type d'objet
if (!($type = xml_fetch_tag($f, $b, $gz))) return false;
if ($type == '/SPIP') return !($import_ok = true);
$id = "id_$type";
$id_objet = 0;
$table = isset($tables[$type]) ? $tables[$type] : $type;
if (!isset($field_desc[$table])){
// recuperer la description de la table pour connaitre ses champs valides
list($nom,$desc) = description_table($table);
if (isset($desc['field']))
$field_desc[$table] = $desc['field'];
else
$field_desc[$table] = NULL;
}
$fields = $field_desc[$table];
// Lire les champs de l'objet
for (;;) {
$b = '';
if (!($col = xml_fetch_tag($f, $b, $gz))) return false;
if ($col == '/'.$type) break;
$value = '';
if (!xml_fetch_tag($f, $value, $gz)) return false;
if (substr($col, 0, 5) == 'lien:') {
$type_lien = substr($col, 5);
$liens[$type_lien][] = '('.$id_objet.','.$value.')';
}
else if ($col != 'maj') {
// tentative de restauration d'une base sauvegardee avec le champ 'images' ; d'experience, ca arrive...
// mieux vaut accepter que canner silencieusement...
if (($type == 'article') && ($col == 'images'))
{
if ($value) { // ne pas afficher de message si on a un champ suppl mais vide
echo "--><br><font color='red'><b>"._T('avis_erreur_sauvegarde', array('type' => $type, 'id_objet' => $id_objet))."</b></font>\n<font color='black'>"._T('avis_colonne_inexistante', array('col' => $col));
if ($col == 'images') echo _T('info_verifier_image');
echo "</font>\n<!--";
$GLOBALS['erreur_restauration'] = true;
}
}
else if ($fields==NULL or isset($fields[$col])) {
$values[$col] = spip_abstract_quote($value);
if ($col == $id) $id_objet = $value;
}
}
}
if (!spip_query("REPLACE $table (" . join(',', array_keys($values)) . ') VALUES (' . join(',', $values) . ')')) {
echo "--><br><font color='red'><b>"._T('avis_erreur_mysql')."</b></font>\n<font color='black'><tt>".spip_sql_error()."</tt></font>\n<!--";
$GLOBALS['erreur_restauration'] = true;
}
if ($type == 'article') {
spip_query("DELETE FROM spip_auteurs_articles WHERE id_article=$id_objet");
spip_query("DELETE FROM spip_documents_articles WHERE id_article=$id_objet");
}
else if ($type == 'rubrique') {
spip_query("DELETE FROM spip_auteurs_rubriques WHERE id_rubrique=$id_objet");
spip_query("DELETE FROM spip_documents_rubriques WHERE id_rubrique=$id_objet");
}
else if ($type == 'breve') {
spip_query("DELETE FROM spip_documents_breves WHERE id_breve=$id_objet");
}
else if ($type == 'mot') {
spip_query("DELETE FROM spip_mots_articles WHERE id_mot=$id_objet");
spip_query("DELETE FROM spip_mots_breves WHERE id_mot=$id_objet");
spip_query("DELETE FROM spip_mots_forum WHERE id_mot=$id_objet");
spip_query("DELETE FROM spip_mots_rubriques WHERE id_mot=$id_objet");
spip_query("DELETE FROM spip_mots_syndic WHERE id_mot=$id_objet");
}
else if ($type == 'auteur') {
spip_query("DELETE FROM spip_auteurs_rubriques WHERE id_auteur=$id_objet");
}
else if ($type == 'message') {
spip_query("DELETE FROM spip_auteurs_messages WHERE id_message=$id_objet");
}
if ($liens) {
reset($liens);
while (list($type_lien, $t) = each($liens)) {
if ($type == 'auteur' OR $type == 'mot' OR $type == 'document')
if ($type_lien == 'syndic' OR $type_lien == 'forum') $table_lien = 'spip_'.$type.'s_'.$type_lien;
else $table_lien = 'spip_'.$type.'s_'.$type_lien.'s';
else
$table_lien = 'spip_'.$type_lien.'s_'.$type.'s';
spip_abstract_insert($table_lien, "($id, id_$type_lien)", join(',', $t));
}
}
return $import_ok = " ";
}
?>