[SPIP] ~maj 3.0.10 --> 3.0.14
[lhc/web/www.git] / www / plugins-dist / medias / formulaires / joindre_document.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2014 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
8 * *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
12
13 if (!defined("_ECRIRE_INC_VERSION")) return;
14
15 function joindre_determiner_mode($mode,$id_document,$objet){
16 if ($mode=='auto'){
17 if (intval($id_document))
18 $mode = sql_getfetsel('mode','spip_documents','id_document='.intval($id_document));
19 if (!in_array($mode,array('choix','document','image'))){
20 $mode='choix';
21 if ($objet AND !in_array(table_objet_sql($objet),explode(',',$GLOBALS['meta']["documents_objets"])))
22 $mode = 'image';
23 }
24 }
25 return $mode;
26 }
27
28 function formulaires_joindre_document_charger_dist($id_document='new',$id_objet=0,$objet='',$mode = 'auto',$galerie = false, $proposer_media=true, $proposer_ftp=true){
29 $valeurs = array();
30 $mode = joindre_determiner_mode($mode,$id_document,$objet);
31
32 $valeurs['id'] = $id_document;
33 $valeurs['_mode'] = $mode;
34
35 $valeurs['url'] = 'http://';
36 $valeurs['fichier_upload'] = $valeurs['_options_upload_ftp'] = $valeurs['_dir_upload_ftp'] = '';
37 $valeurs['joindre_upload'] = $valeurs['joindre_distant'] = $valeurs['joindre_ftp'] = $valeurs['joindre_mediatheque'] = '';
38
39 $valeurs['editable'] = ' ';
40 if (intval($id_document))
41 $valeurs['editable'] = autoriser('modifier','document',$id_document)?' ':'';
42
43 $valeurs['proposer_media'] = is_string($proposer_media) ? (preg_match('/^(false|non|no)$/i', $proposer_media) ? false : true) : $proposer_media;
44 $valeurs['proposer_ftp'] = is_string($proposer_ftp) ? (preg_match('/^(false|non|no)$/i', $proposer_ftp) ? false : true) : $proposer_ftp;
45
46 # regarder si un choix d'upload FTP est vraiment possible
47 if (
48 $valeurs['proposer_ftp']
49 AND test_espace_prive() # ??
50 AND ($mode != 'image') AND ($mode != 'vignette') # si c'est pour un document
51 //AND !$vignette_de_doc # pas pour une vignette (NB: la ligne precedente suffit, mais si on la supprime il faut conserver ce test-ci)
52 AND $GLOBALS['flag_upload']
53 ) {
54 include_spip('inc/documents');
55 if ($dir = determine_upload('documents')) {
56 // quels sont les docs accessibles en ftp ?
57 $valeurs['_options_upload_ftp'] = joindre_options_upload_ftp($dir, $mode);
58 // s'il n'y en a pas, on affiche un message d'aide
59 // en mode document, mais pas en mode image
60 if ($valeurs['_options_upload_ftp'] OR ($mode == 'document' OR $mode=='choix'))
61 $valeurs['_dir_upload_ftp'] = "<b>".joli_repertoire($dir)."</b>";
62 }
63 }
64 // On ne propose le FTP que si on a des choses a afficher
65 $valeurs['proposer_ftp'] = ($valeurs['_options_upload_ftp'] or $valeurs['_dir_upload_ftp']);
66
67 if ($galerie){
68 # passer optionnellement une galerie jointe au form
69 # plus utilise nativement, on prefere la mise a jour
70 # apres upload par ajaxReload('documents')
71 $valeurs['_galerie'] = $galerie;
72 }
73 if ($objet AND $id_objet){
74 $valeurs['id_objet'] = $id_objet;
75 $valeurs['objet'] = $objet;
76 $valeurs['refdoc_joindre'] = '';
77 if ($valeurs['editable']){
78 include_spip('inc/autoriser');
79 $valeurs['editable'] = autoriser('joindredocument',$objet,$id_objet)?' ':'';
80 }
81 }
82
83 return $valeurs;
84 }
85
86
87 function formulaires_joindre_document_verifier_dist($id_document='new',$id_objet=0,$objet='',$mode = 'auto',$galerie = false, $proposer_media=true, $proposer_ftp=true){
88 include_spip('inc/joindre_document');
89
90 $erreurs = array();
91 // on joint un document deja dans le site
92 if (_request('joindre_mediatheque')){
93 $refdoc_joindre = intval(preg_replace(',^(doc|document|img),','',_request('refdoc_joindre')));
94 if (!sql_getfetsel('id_document','spip_documents','id_document='.intval($refdoc_joindre)))
95 $erreurs['message_erreur'] = _T('medias:erreur_aucun_document');
96 }
97 // sinon c'est un upload
98 else {
99 $files = joindre_trouver_fichier_envoye();
100 if (is_string($files))
101 $erreurs['message_erreur'] = $files;
102 elseif(is_array($files)){
103 // erreur si on a pas trouve de fichier
104 if (!count($files))
105 $erreurs['message_erreur'] = _T('medias:erreur_aucun_fichier');
106
107 else{
108 // regarder si on a eu une erreur sur l'upload d'un fichier
109 foreach($files as $file){
110 if (isset($file['error'])
111 AND $test = joindre_upload_error($file['error'])){
112 if (is_string($test))
113 $erreurs['message_erreur'] = $test;
114 else
115 $erreurs['message_erreur'] = _T('medias:erreur_aucun_fichier');
116 }
117 }
118
119 // si ce n'est pas deja un post de zip confirme
120 // regarder si il faut lister le contenu du zip et le presenter
121 if (!count($erreurs)
122 AND !_request('joindre_zip')
123 AND $contenu_zip = joindre_verifier_zip($files)){
124 list($fichiers,$erreurs,$tmp_zip) = $contenu_zip;
125 if ($fichiers)
126 $erreurs['lister_contenu_archive'] = recuperer_fond("formulaires/inc-lister_archive_jointe",array('chemin_zip'=>$tmp_zip,'liste_fichiers_zip'=>$fichiers,'erreurs_fichier_zip'=>$erreurs));
127 else
128 $erreurs['message_erreur'] = _T('medias:erreur_aucun_fichier');
129 }
130 }
131 }
132
133 if (count($erreurs) AND defined('_tmp_dir'))
134 effacer_repertoire_temporaire(_tmp_dir);
135 }
136
137 return $erreurs;
138 }
139
140 function formulaires_joindre_document_traiter_dist($id_document='new',$id_objet=0,$objet='',$mode = 'auto',$galerie = false, $proposer_media=true, $proposer_ftp=true){
141 $res = array('editable'=>true);
142 $ancre = '';
143 // on joint un document deja dans le site
144 if (_request('joindre_mediatheque')){
145 $refdoc_joindre = _request('refdoc_joindre');
146 $refdoc_joindre = strtr($refdoc_joindre,";,"," ");
147 $refdoc_joindre = preg_replace(',\b(doc|document|img),','',$refdoc_joindre);
148 // expliciter les intervales xxx-yyy
149 while(preg_match(",\b(\d+)-(\d+)\b,",$refdoc_joindre,$m))
150 $refdoc_joindre = str_replace($m[0],implode(" ",range($m[1],$m[2])),$refdoc_joindre);
151 $refdoc_joindre = explode(" ",$refdoc_joindre);
152 include_spip('action/editer_document');
153 foreach($refdoc_joindre as $j){
154 if ($j = intval(preg_replace(',^(doc|document|img),','',$j))){
155 // lier le parent en plus
156 $champs = array('ajout_parents' => array("$objet|$id_objet"));
157 document_modifier($j,$champs);
158 if (!$ancre)
159 $ancre = $j;
160 $sel[] = $j;
161 $res['message_ok'] = _T('medias:document_attache_succes');
162 }
163 }
164 if ($sel)
165 $res['message_ok'] = singulier_ou_pluriel(count($sel),'medias:document_attache_succes','medias:nb_documents_attache_succes');
166 set_request('refdoc_joindre',''); // vider la saisie
167 }
168 // sinon c'est un upload
169 else {
170 $ajouter_documents = charger_fonction('ajouter_documents', 'action');
171
172 $mode = joindre_determiner_mode($mode,$id_document,$objet);
173 include_spip('inc/joindre_document');
174 $files = joindre_trouver_fichier_envoye();
175
176 $nouveaux_doc = $ajouter_documents($id_document,$files,$objet,$id_objet,$mode);
177
178 if (defined('_tmp_zip'))
179 unlink(_tmp_zip);
180 if (defined('_tmp_dir'))
181 effacer_repertoire_temporaire(_tmp_dir);
182
183 // checker les erreurs eventuelles
184 $messages_erreur = array();
185 $nb_docs = 0;
186 $sel = array();
187 foreach ($nouveaux_doc as $doc) {
188 if (!is_numeric($doc))
189 $messages_erreur[] = $doc;
190 // cas qui devrait etre traite en amont
191 elseif(!$doc)
192 $messages_erreur[] = _T('medias:erreur_insertion_document_base',array('fichier'=>'<em>???</em>'));
193 else{
194 if (!$ancre)
195 $ancre = $doc;
196 $sel[] = $doc;
197 }
198 }
199 if (count($messages_erreur))
200 $res['message_erreur'] = implode('<br />',$messages_erreur);
201 if ($sel)
202 $res['message_ok'] = singulier_ou_pluriel(count($sel),'medias:document_installe_succes','medias:nb_documents_installe_succes');
203 if ($ancre)
204 $res['redirect'] = "#doc$ancre";
205 }
206 if (count($sel) OR isset($res['message_ok'])){
207 $callback = "";
208 if ($ancre)
209 $callback .= "jQuery('#doc$ancre a.editbox').eq(0).focus();";
210 if (count($sel)){
211 // passer les ids document selectionnes aux pipelines
212 $res['ids'] = $sel;
213
214 $sel = "#doc".implode(",#doc",$sel);
215 $callback .= "jQuery('$sel').animateAppend();";
216 }
217 $js = "if (window.jQuery) jQuery(function(){ajaxReload('documents',{callback:function(){ $callback }});});";
218 $js = "<script type='text/javascript'>$js</script>";
219 if (isset($res['message_erreur']))
220 $res['message_erreur'].= $js;
221 else
222 $res['message_ok'] .= $js;
223 }
224
225 return $res;
226 }
227
228 /**
229 * Retourner le contenu du select HTML d'utilisation de fichiers envoyes
230 *
231 * @param string $dir
232 * @param string $mode
233 * @return string
234 */
235 function joindre_options_upload_ftp($dir, $mode = 'document') {
236 $fichiers = preg_files($dir);
237 $exts = $dirs = $texte_upload = array();
238
239 // en mode "charger une image", ne proposer que les inclus
240 $inclus = ($mode == 'image' OR $mode =='vignette')
241 ? " AND inclus='image'"
242 : '';
243
244 foreach ($fichiers as $f) {
245 $f = preg_replace(",^$dir,",'',$f);
246 if (preg_match(",\.([^.]+)$,", $f, $match)) {
247 $ext = strtolower($match[1]);
248 if (!isset($exts[$ext])) {
249 include_spip('action/ajouter_documents');
250 $ext = corriger_extension($ext);
251 if (sql_fetsel('extension', 'spip_types_documents', $a = "extension='$ext'" . $inclus))
252 $exts[$ext] = 'oui';
253 else $exts[$ext] = 'non';
254 }
255
256 $k = 2*substr_count($f,'/');
257 $n = strrpos($f, "/");
258 if ($n === false)
259 $lefichier = $f;
260 else {
261 $lefichier = substr($f, $n+1, strlen($f));
262 $ledossier = substr($f, 0, $n);
263 if (!in_array($ledossier, $dirs)) {
264 $texte_upload[] = "\n<option value=\"$ledossier\">"
265 . str_repeat("&nbsp;",$k)
266 ._T('medias:tout_dossier_upload', array('upload' => $ledossier))
267 ."</option>";
268 $dirs[]= $ledossier;
269 }
270 }
271
272 if ($exts[$ext] == 'oui')
273 $texte_upload[] = "\n<option value=\"$f\">" .
274 str_repeat("&nbsp;",$k+2) .
275 $lefichier .
276 "</option>";
277 }
278 }
279
280 $texte = join('', $texte_upload);
281 if (count($texte_upload)>1) {
282 $texte = "\n<option value=\"/\" style='font-weight: bold;'>"
283 ._T('medias:info_installer_tous_documents')
284 ."</option>" . $texte;
285 }
286
287 return $texte;
288 }
289
290 /**
291 * Lister les fichiers contenus dans un zip
292 *
293 * @param unknown_type $files
294 * @return unknown
295 */
296 function joindre_liste_contenu_tailles_archive($files) {
297 include_spip('inc/charsets'); # pour le nom de fichier
298
299 $res = '';
300 if (is_array($files))
301 foreach ($files as $nom => $file) {
302 $nom = translitteration($nom);
303 $date = date_interface(date("Y-m-d H:i:s", $file['mtime']));
304
305 $taille = taille_en_octets($file['size']);
306 $res .= "<li title=\"".attribut_html($title)."\"><b>$nom</b> &ndash; $taille<br />&nbsp; $date</li>\n";
307 }
308
309 return $res;
310 }
311
312 function joindre_liste_erreurs_to_li($erreurs){
313 if (count($erreurs)==1)
314 return "<p>".reset($erreurs)."</p>";
315
316 $res = implode("</li><li>",$erreurs);
317 if (strlen($res)) $res = "<li>$res</li></ul>";
318 if (count($erreurs)>4)
319 $res = "<p style='cursor:pointer;' onclick='jQuery(this).siblings(\"ul\").toggle();return false;'>"._T("medias:erreurs_voir",array('nb'=>count($erreurs)))."</p><ul class=\"spip none-js\">".$res."</ul>";
320 else
321 $res = "<ul class=\"spip\">$res</ul>";
322 return $res;
323 }
324
325 ?>