<?php

/**
 * Fichier gérant l'installation et désinstallation du plugin
 *
 * @package SPIP\Formidable\Installation
**/

// Sécurité
if (!defined("_ECRIRE_INC_VERSION")) return;

/**
 * Installation/maj des tables de formidable...
 *
 * @param string $nom_meta_base_version
 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
 * @param string $version_cible
 *     Version du schéma de données dans ce plugin (déclaré dans paquet.xml)
 * @return void
 */
function formidable_upgrade($nom_meta_base_version, $version_cible){
	// Création des tables
	include_spip('base/create');
	include_spip('base/abstract_sql');

	$maj = array();
	$maj['create'] = array(
		array('maj_tables',array(
			'spip_formulaires',
			'spip_formulaires_reponses',
			'spip_formulaires_reponses_champs',
			'spip_formulaires_liens')),
		array('formidable_importer_forms'),
		array('formidable_importer_forms_donnees'),
		array('formidable_associer_forms'),
	);

	// Ajout du choix de ce qu'on affiche à la fin des traitements
	$maj['0.4.0'] = array(array('maj_tables',array('spip_formulaires')));
	// Ajout d'une URL de redirection
	$maj['0.5.0'] = array(array('maj_tables',array('spip_formulaires')));
	// Modif du type du message de retour pour pouvoir mettre plus de chose
	$maj['0.5.1'] = array(array('sql_alter','TABLE spip_formulaires CHANGE message_retour message_retour text NOT NULL default ""'));
	// Passer le champ saisies en longtext pour permettre d'y stocker des formulaires longs
	$maj['0.5.2'] = array(array('sql_alter','TABLE spip_formulaires CHANGE saisies saisies longtext NOT NULL default ""'));
	// Ajouter un champ date de création
	$maj['0.5.3'] = array(array('sql_alter','TABLE spip_formulaires ADD date_crea datetime NOT NULL DEFAULT "0000-00-00 00:00:00"'));
	// Renommer la date de création (pas d'abbréviations dans les noms)
	$maj['0.5.5'] = array(array('sql_alter','TABLE spip_formulaires CHANGE date_crea date_creation datetime NOT NULL DEFAULT "0000-00-00 00:00:00"'));

	// statut publie sur les formulaires sans statut
	$maj['0.5.6'] = array(
		array('sql_updateq','spip_formulaires',array('statut'=>'publie'),"statut=".sql_quote('')),
	);

	include_spip('base/upgrade');
	maj_plugin($nom_meta_base_version, $version_cible, $maj);
}

/**
 * Désinstallation/suppression des tables de formidable
 *
 * @param string $nom_meta_base_version
 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
 * @return void
 */
function formidable_vider_tables($nom_meta_base_version){

	include_spip('inc/meta');
	include_spip('base/abstract_sql');

	// On efface les tables du plugin
	sql_drop_table('spip_formulaires');
	sql_drop_table('spip_formulaires_reponses');
	sql_drop_table('spip_formulaires_reponses_champs');
	sql_drop_table('spip_formulaires_liens');

	// on efface les champs d'import de f&t si il y a lieu
	$trouver_table = charger_fonction("trouver_table","base");
	if ($trouver_table('spip_forms')){
		sql_alter("TABLE spip_forms DROP id_formulaire");
	}
	if ($trouver_table('spip_forms_donnees')){
		sql_alter("TABLE spip_forms_donnees DROP id_formulaires_reponse");
	}


	// On efface la version entregistrée
	effacer_meta($nom_meta_base_version);
}

/**
 * Associer les <formXX> issus de f&t aux articles concernes
 */
function formidable_associer_forms(){
	include_spip("inc/rechercher");
	include_spip("inc/editer_liens");
	$forms = sql_allfetsel("*","spip_formulaires","identifiant REGEXP ".sql_quote('^form[0-9]+$'));
	foreach($forms as $form){
		if (!sql_countsel("spip_formulaires_liens","id_formulaire=".intval($form['id_formulaire']))){
			$articles = array();
			$id = $form['identifiant'];
			#var_dump($id);
			$res = recherche_en_base("/<{$id}[>|]/","article");
			#var_dump($res);
			if (count($res) AND isset($res['article'])){
				foreach($res['article'] as $id_article=>$details){
					$articles[] = $id_article;
				}
			}
			#var_dump($form['id_formulaire']);
			#var_dump($articles);
			objet_associer(array('formulaire'=>array($form['id_formulaire'])),array('article'=>$articles));
		}
		if (time()>_TIME_OUT)
			return;
	}
}

/**
 * Importer les formulaires de f&t
 */
function formidable_importer_forms(){
	$trouver_table = charger_fonction("trouver_table","base");
	if ($trouver_table('spip_forms')){
		sql_alter("TABLE spip_forms ADD id_formulaire bigint(21) NOT NULL DEFAULT 0");

		include_spip("echanger/formulaire/forms");

		$forms = sql_allfetsel("*","spip_forms",'id_formulaire=0 AND type_form='.sql_quote('')." OR type_form=".sql_quote('sondage'),'','id_form');
		foreach($forms as $form){
			$formulaire = array();
			// configurer le formulaire (titre etc)
			forms_configure_formulaire($form,$formulaire);

			// identifiant formXX puisqu'on est en installation, pas de risque de conflits
			// et facilite la migration de modele
			$formulaire['identifiant'] = "form".$form['id_form'];
			// on peut faire ca aussi puisqu'on est a l'installation
			$formulaire['id_formulaire'] = $form['id_form'];

			$fields = sql_allfetsel("*","spip_forms_champs","id_form=".intval($form['id_form']),"","rang");
			foreach($fields as $field){
				$choix = sql_allfetsel("*","spip_forms_champs_choix","id_form=".intval($form['id_form'])." AND champ=".sql_quote($field['champ']),'','rang');
				if (count($choix))
					$field['choix'] = $choix;

				if ($saisie = forms_champ_vers_saisie($field))
					$formulaire['saisies'][] = $saisie;
			}

			// les traitements
			forms_configure_traitement_formulaire($form,$formulaire);

			// si ce formulaire a des reponses on le met en publie
			if (sql_countsel("spip_forms_donnees","id_form=".intval($form['id_form'])))
				$formulaire['statut'] = 'publie';

			$id_formulaire = forms_importe_en_base($formulaire);
			spip_log("Import spip_forms #".$form['id_form']." en spip_formulaires #$id_formulaire","maj"._LOG_INFO_IMPORTANTE);

			sql_update('spip_forms',array('id_formulaire'=>$id_formulaire),'id_form='.intval($form['id_form']));

			if (time()>_TIME_OUT)
				return;
		}

	}

	include_spip("inc/drapeau_edition");
	debloquer_tous($GLOBALS['visiteur_session']['id_auteur']);
}

function formidable_importer_forms_donnees(){
	$trouver_table = charger_fonction("trouver_table","base");
	if ($trouver_table('spip_forms')){
		sql_alter("TABLE spip_forms_donnees ADD id_formulaires_reponse bigint(21) NOT NULL DEFAULT 0");

		// 2 champs de plus pour ne pas perdre des donnees
		sql_alter("TABLE spip_formulaires_reponses ADD url varchar(255) NOT NULL default ''");
		sql_alter("TABLE spip_formulaires_reponses ADD confirmation varchar(10) NOT NULL default ''");

		// table de correspondance id_form=>id_formulaire
		$rows = sql_allfetsel("id_form,id_formulaire","spip_forms","id_formulaire>0");
		$trans = array();
		foreach($rows as $row)
			$trans[$row['id_form']] = $row['id_formulaire'];

		$rows = sql_allfetsel("*","spip_forms_donnees",sql_in('id_form',array_keys($trans))." AND id_formulaires_reponse=0",'','id_donnee','0,100');
		do {

			foreach($rows as $row){

				#var_dump($row);
				$reponse = array(
					"id_formulaire" => $trans[$row['id_form']],
					"date" => $row["date"],
					"ip" => $row["ip"],
					"id_auteur" => $row["id_auteur"],
					"cookie" => $row["cookie"],
					"statut" => $row["statut"],
					"url" => $row["url"],
					"confirmation" => $row["confirmation"],
				);

				#var_dump($reponse);
				$id_formulaires_reponse = sql_insertq("spip_formulaires_reponses",$reponse);
				#var_dump($id_formulaires_reponse);
				if ($id_formulaires_reponse){
					$donnees = sql_allfetsel("$id_formulaires_reponse as id_formulaires_reponse,champ as nom,valeur","spip_forms_donnees_champs","id_donnee=".intval($row['id_donnee']));
					sql_insertq_multi("spip_formulaires_reponses_champs",$donnees);
					// et on marque la donnee pour ne pas la rejouer
					sql_update("spip_forms_donnees",array("id_formulaires_reponse"=>$id_formulaires_reponse),"id_donnee=".intval($row['id_donnee']));
				}
				if (time()>_TIME_OUT)
					return;
			}

			if (time()>_TIME_OUT)
				return;

		} while ($rows = sql_allfetsel("*","spip_forms_donnees",sql_in('id_form',array_keys($trans))." AND id_formulaires_reponse=0",'','id_donnee','0,100'));

	}

}