499a9339f544d8c94683f965f92e8b126d86ea25
[ptitvelo/web/www.git] / www / plugins-dist / svp / action / teleporter.php
1 <?php
2 /**
3 * Gestion de l'action teleporter
4 *
5 * @plugin SVP pour SPIP
6 * @license GPL
7 * @package SPIP\SVP\Actions
8 */
9
10
11 /**
12 * Téléporter et déballer un composant
13 *
14 * @param string $methode
15 * http|git|svn|...
16 * @param string $source
17 * URL source du composant
18 * @param string $dest
19 * Chemin du répertoire où déballer le composant. Inclus le dernier segment
20 * @param array $options
21 * revision => ''
22 * --ignore-externals
23 * @return bool|string
24 * String : texte d'une erreur
25 * true si l'opération est correctement réalisée
26 */
27 function action_teleporter_composant_dist($methode,$source,$dest,$options=array()){
28
29 # Si definie a '', le chargeur est interdit ; mais on n'aurait de toutes
30 # facons jamais pu venir ici avec toutes les securisations faites :^)
31 if (!_DIR_PLUGINS_AUTO) die('jamais');
32
33 // verifier que la methode est connue
34 if (!$teleporter = charger_fonction($methode,"teleporter",true)){
35 spip_log("Methode $methode inconnue pour teleporter $source vers $dest","teleport"._LOG_ERREUR);
36 return _T('svp:erreur_teleporter_methode_inconue',array('methode' => $methode));
37 }
38
39 if (!$dest = teleporter_verifier_destination($d = $dest)){
40 spip_log("Rerpertoire $d non accessible pour teleporter $source vers $d","teleport"._LOG_ERREUR);
41 return _T('svp:erreur_teleporter_destination_erreur',array('dir' => $d));
42 #$texte = "<p>"._T('plugin_erreur_droit1',array('dest'=>$dest))."</p>"
43 # . "<p>"._T('plugin_erreur_droit2').aide('install0')."</p>";
44 }
45
46 # destination temporaire des fichiers si besoin
47 $options['dir_tmp'] = sous_repertoire(_DIR_CACHE, 'chargeur');
48
49 return $teleporter($methode,$source,$dest,$options);
50 }
51
52
53 /**
54 * Vérifier et préparer l'arborescence jusqu'au répertoire parent
55 *
56 * @param string $dest
57 * @return bool|string
58 * false en cas d'échec
59 * Chemin du répertoire sinon
60 */
61 function teleporter_verifier_destination($dest){
62 $dest = rtrim($dest,"/");
63 $final = basename($dest);
64 $base = dirname($dest);
65 $create = array();
66 // on cree tout le chemin jusqu'a dest non inclus
67 while (!is_dir($base)){
68 $create[] = basename($base);
69 $base = dirname($base);
70 }
71 while (count($create)){
72 if (!is_writable($base))
73 return false;
74 $base = sous_repertoire($base,array_pop($create));
75 if (!$base)
76 return false;
77 }
78
79 if (!is_writable($base))
80 return false;
81
82 return $base."/$final";
83 }
84
85 /**
86 * Déplace un répertoire pour libérer l'emplacement.
87 *
88 * Si le répertoire donné existe, le déplace dans un répertoire de backup.
89 * Si ce backup existe déjà, il est supprimé auparavant.
90 * Retourne le nouveau chemin du répertoire.
91 *
92 * @param string $dest
93 * Chemin du répertoire à déplacer
94 * @return string
95 * Nouveau chemin du répertoire s'il existait,
96 * Chaîne vide sinon
97 **/
98 function teleporter_nettoyer_vieille_version($dest){
99 $old = "";
100 if (is_dir($dest)){
101 $dir = dirname($dest);
102 $base = basename($dest);
103 $old="$dir/.$base.bck";
104 if (is_dir($old))
105 supprimer_repertoire($old);
106 rename($dest,$old);
107 }
108 return $old;
109 }