4 if (!defined("_ECRIRE_INC_VERSION")) return;
6 function echanger_formulaire_yaml_exporter_dist($id_formulaire){
7 include_spip('base/abstract_sql');
8 include_spip('inc/yaml');
9 $id_formulaire = intval($id_formulaire);
12 if ($id_formulaire > 0){
13 // On récupère le formulaire
14 $formulaire = sql_fetsel(
17 'id_formulaire = '.$id_formulaire
20 // On décompresse les trucs sérialisés
21 $formulaire['saisies'] = unserialize($formulaire['saisies']);
22 $formulaire['traitements'] = unserialize($formulaire['traitements']);
25 $export = yaml_encode($formulaire);
28 Header("Content-Type: text/x-yaml;");
29 Header('Content-Disposition: attachment; filename=formulaire-'.$formulaire['identifiant'].'.yaml');
30 Header("Content-Length: ".strlen($export));
35 function echanger_formulaire_yaml_importer_dist($fichier){
37 lire_fichier($fichier, $yaml);
38 // Si on a bien recupere une chaine on tente de la decoder
40 include_spip('inc/yaml');
41 $formulaire = yaml_decode($yaml);
42 // Si le decodage marche on importe alors le contenu
43 if (is_array($formulaire)){
44 include_spip('action/editer_formulaire');
45 // On enlève les champs inutiles
46 unset($formulaire['id_formulaire']);
47 // On vérifie que l'identifiant n'existe pas déjà
48 $deja = sql_getfetsel(
51 'identifiant = '.sql_quote($formulaire['identifiant'])
54 $formulaire['identifiant'] .= '_'.date('Ymd_His');
57 // On insère un nouveau formulaire
58 $id_formulaire = formulaire_inserer();
59 // Si ça a marché on transforme les tableaux et on modifie les champs
60 if ($id_formulaire > 0){
61 if (is_array($formulaire['saisies'])){
62 $formulaire['saisies'] = serialize($formulaire['saisies']);
64 if (is_array($formulaire['traitements'])){
65 $formulaire['traitements'] = serialize($formulaire['traitements']);
68 $erreur = formulaire_modifier($id_formulaire, $formulaire);
73 if ($id_formulaire and !$erreur){
74 return $id_formulaire;
77 return _T('formidable:erreur_importer_yaml').' : '.$erreur;