Dotclear

source: admin/media.php @ 2614:db6f6a1f4f25

Revision 2614:db6f6a1f4f25, 18.5 KB checked in by Nicolas <nikrou77@…>, 12 years ago (diff)

Move legacy editor to a plugin. First step for alternate editors.
Addresses #1896

Line 
1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
6# Copyright (c) 2003-2013 Olivier Meunier & Association Dotclear
7# Licensed under the GPL version 2.0 license.
8# See LICENSE file or
9# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
10#
11# -- END LICENSE BLOCK -----------------------------------------
12
13/* HTML page
14-------------------------------------------------------- */
15require dirname(__FILE__).'/../inc/admin/prepend.php';
16
17dcPage::check('media,media_admin');
18
19$post_id = !empty($_GET['post_id']) ? (integer) $_GET['post_id'] : null;
20if ($post_id) {
21     $post = $core->blog->getPosts(array('post_id'=>$post_id,'post_type'=>''));
22     if ($post->isEmpty()) {
23          $post_id = null;
24     }
25     $post_title = $post->post_title;
26     $post_type = $post->post_type;
27     unset($post);
28}
29$d = isset($_REQUEST['d']) ? $_REQUEST['d'] : null;
30$dir = null;
31
32$page = !empty($_GET['page']) ? max(1,(integer) $_GET['page']) : 1;
33$nb_per_page = ((integer) $core->auth->user_prefs->interface->media_by_page ? (integer) $core->auth->user_prefs->interface->media_by_page : 30);
34
35# We are on home not comming from media manager
36if ($d === null && isset($_SESSION['media_manager_dir'])) {
37     # We get session information
38     $d = $_SESSION['media_manager_dir'];
39}
40
41if (!isset($_GET['page']) && isset($_SESSION['media_manager_page'])) {
42     $page = $_SESSION['media_manager_page'];
43}
44
45# We set session information about directory and page
46if ($d) {
47     $_SESSION['media_manager_dir'] = $d;
48} else {
49     unset($_SESSION['media_manager_dir']);
50}
51if ($page != 1) {
52     $_SESSION['media_manager_page'] = $page;
53} else {
54     unset($_SESSION['media_manager_page']);
55}
56
57# Sort combo
58$sort_combo = array(
59     __('By names, in ascending order') => 'name-asc',
60     __('By names, in descending order') => 'name-desc',
61     __('By dates, in ascending order') => 'date-asc',
62     __('By dates, in descending order') => 'date-desc'
63     );
64
65if (!empty($_GET['file_sort']) && in_array($_GET['file_sort'],$sort_combo)) {
66     $_SESSION['media_file_sort'] = $_GET['file_sort'];
67}
68$file_sort = !empty($_SESSION['media_file_sort']) ? $_SESSION['media_file_sort'] : null;
69$nb_per_page = !empty($_SESSION['nb_per_page']) ? (integer)$_SESSION['nb_per_page'] : $nb_per_page;
70if (!empty($_GET['nb_per_page']) && (integer)$_GET['nb_per_page'] > 0) {
71     $nb_per_page = $_SESSION['nb_per_page'] = (integer)$_GET['nb_per_page'];
72}
73
74$popup = (integer) !empty($_GET['popup']);
75
76$page_url = 'media.php?popup='.$popup.'&post_id='.$post_id;
77$page_url = $core->callBehavior('adminMediaURL',$page_url);
78
79if ($popup) {
80     $open_f = array('dcPage','openPopup');
81     $close_f = array('dcPage','closePopup');
82} else {
83     $open_f = array('dcPage','open');
84     $close_f = create_function('',"dcPage::helpBlock('core_media'); dcPage::close();");
85}
86
87$core_media_writable = false;
88try {
89     $core->media = new dcMedia($core);
90     if ($file_sort) {
91          $core->media->setFileSort($file_sort);
92     }
93     $core->media->chdir($d);
94     $core->media->getDir();
95     $core_media_writable = $core->media->writable();
96     $dir =& $core->media->dir;
97     if  (!$core_media_writable) {
98//        throw new Exception('you do not have sufficient permissions to write to this folder: ');
99     }
100} catch (Exception $e) {
101     $core->error->add($e->getMessage());
102}
103
104# Zip download
105if (!empty($_GET['zipdl']) && $core->auth->check('media_admin',$core->blog->id))
106{
107     try
108     {
109          @set_time_limit(300);
110          $fp = fopen('php://output','wb');
111          $zip = new fileZip($fp);
112          $zip->addExclusion('#(^|/).(.*?)_(m|s|sq|t).jpg$#');
113          $zip->addDirectory($core->media->root.'/'.$d,'',true);
114
115          header('Content-Disposition: attachment;filename='.($d ? $d : 'media').'.zip');
116          header('Content-Type: application/x-zip');
117          $zip->write();
118          unset($zip);
119          exit;
120     }
121     catch (Exception $e)
122     {
123          $core->error->add($e->getMessage());
124     }
125}
126
127# New directory
128if ($dir && !empty($_POST['newdir']))
129{
130     try {
131          $core->media->makeDir($_POST['newdir']);
132          dcPage::addSuccessNotice(sprintf(
133               __('Directory "%s" has been successfully created.'),
134               html::escapeHTML($_POST['newdir']))
135          );
136          http::redirect($page_url.'&d='.rawurlencode($d));
137     } catch (Exception $e) {
138          $core->error->add($e->getMessage());
139     }
140}
141
142# Adding a file
143if ($dir && !empty($_FILES['upfile'])) {
144  // only one file per request : @see option singleFileUploads in admin/js/jsUpload/jquery.fileupload
145     $upfile = array('name' => $_FILES['upfile']['name'][0],
146          'type' => $_FILES['upfile']['type'][0],
147          'tmp_name' => $_FILES['upfile']['tmp_name'][0],
148          'error' => $_FILES['upfile']['error'][0],
149          'size' => $_FILES['upfile']['size'][0]
150          );
151
152     if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])) {
153          header('Content-type: application/json');
154          $message = array();
155
156          try {
157               files::uploadStatus($upfile);
158               $new_file_id = $core->media->uploadFile($upfile['tmp_name'], $upfile['name']);
159
160               $message['files'][] = array('name' => $upfile['name'],
161                    'size' => $upfile['size'],
162                    'html' => mediaItemLine($core->media->getFile($new_file_id), 1)
163                    );
164          } catch (Exception $e) {
165               $message['files'][] = array('name' => $upfile['name'],
166                    'size' => $upfile['size'],
167                    'error' => $e->getMessage()
168                    );
169          }
170          echo json_encode($message);
171          exit();
172     } else {
173          try {
174               files::uploadStatus($upfile);
175
176               $f_title = (isset($_POST['upfiletitle']) ? $_POST['upfiletitle'] : '');
177               $f_private = (isset($_POST['upfilepriv']) ? $_POST['upfilepriv'] : false);
178
179               $core->media->uploadFile($upfile['tmp_name'], $upfile['name'], $f_title, $f_private);
180
181               dcPage::addSuccessNotice(__('Files have been successfully uploaded.'));
182               http::redirect($page_url.'&d='.rawurlencode($d));
183          } catch (Exception $e) {
184               $core->error->add($e->getMessage());
185          }
186     }
187}
188
189# Removing items
190if ($dir && !empty($_POST['medias']) && !empty($_POST['delete_medias'])) {
191     try {
192          foreach ($_POST['medias'] as $media) {
193               $core->media->removeItem(rawurldecode($media));
194          }
195          dcPage::addSuccessNotice(
196               sprintf(__('Successfully delete one media.',
197                            'Successfully delete %d medias.',
198                            count($_POST['medias'])
199                            ),
200                            count($_POST['medias'])
201               )
202          );
203          http::redirect($page_url.'&d='.rawurlencode($d));
204     } catch (Exception $e) {
205          $core->error->add($e->getMessage());
206     }
207}
208
209# Removing item from popup only
210if ($dir && !empty($_POST['rmyes']) && !empty($_POST['remove']))
211{
212     $_POST['remove'] = rawurldecode($_POST['remove']);
213
214     try {
215          if (is_dir(path::real($core->media->getPwd().'/'.path::clean($_POST['remove'])))) {
216               $msg = __('Directory has been successfully removed.');
217          } else {
218               $msg = __('File has been successfully removed.');
219          }
220          $core->media->removeItem($_POST['remove']);
221          dcPage::addSuccessNotice($msg);
222          http::redirect($page_url.'&d='.rawurlencode($d));
223     } catch (Exception $e) {
224          $core->error->add($e->getMessage());
225     }
226}
227
228# Rebuild directory
229if ($dir && $core->auth->isSuperAdmin() && !empty($_POST['rebuild']))
230{
231     try {
232          $core->media->rebuild($d);
233
234          dcPage::success(sprintf(
235               __('Directory "%s" has been successfully rebuilt.'),
236               html::escapeHTML($d))
237          );
238          http::redirect($page_url.'&d='.rawurlencode($d));
239     } catch (Exception $e) {
240          $core->error->add($e->getMessage());
241     }
242}
243
244# DISPLAY confirm page for rmdir & rmfile
245if ($dir && !empty($_GET['remove']) && empty($_GET['noconfirm']))
246{
247     call_user_func($open_f,__('Media manager'),'',
248          dcPage::breadcrumb(
249               array(
250                    html::escapeHTML($core->blog->name) => '',
251                    __('Media manager') => '',
252                    __('confirm removal') => ''
253               ),
254               array('home_link' => !$popup)
255          )
256     );
257
258     echo
259     '<form action="'.html::escapeURL($page_url).'" method="post">'.
260     '<p>'.sprintf(__('Are you sure you want to remove %s?'),
261          html::escapeHTML($_GET['remove'])).'</p>'.
262     '<p><input type="submit" value="'.__('Cancel').'" /> '.
263     ' &nbsp; <input type="submit" name="rmyes" value="'.__('Yes').'" />'.
264     form::hidden('d',$d).
265     $core->formNonce().
266     form::hidden('remove',html::escapeHTML($_GET['remove'])).'</p>'.
267     '</form>';
268
269     call_user_func($close_f);
270     exit;
271}
272
273/* DISPLAY Main page
274-------------------------------------------------------- */
275$core->auth->user_prefs->addWorkspace('interface');
276$user_ui_enhanceduploader = $core->auth->user_prefs->interface->enhanceduploader;
277
278if (!isset($core->media)) {
279     $breadcrumb = dcPage::breadcrumb(
280          array(
281               html::escapeHTML($core->blog->name) => '',
282               __('Media manager') => ''
283          ),
284          array('home_link' => !$popup)
285     );
286} else {
287     $breadcrumb_media = $core->media->breadCrumb(html::escapeURL($page_url).'&amp;d=%s','<span class="page-title">%s</span>');
288     if ($breadcrumb_media == '') {
289          $breadcrumb = dcPage::breadcrumb(
290               array(
291                    html::escapeHTML($core->blog->name) => '',
292                    __('Media manager') => ''
293               ),
294               array('home_link' => !$popup)
295          );
296     } else {
297          $breadcrumb = dcPage::breadcrumb(
298               array(
299                    html::escapeHTML($core->blog->name) => '',
300                    __('Media manager') => html::escapeURL($page_url.'&d='),
301                    $breadcrumb_media => ''
302               ),
303               array(
304                    'home_link' => !$popup,
305                    'hl' => false
306               )
307          );
308     }
309}
310
311call_user_func($open_f,__('Media manager'),
312     dcPage::jsLoad('js/_media.js').
313     ($core_media_writable ? dcPage::jsUpload(array('d='.$d)) : ''),
314     $breadcrumb
315     );
316
317if ($popup) {
318     // Display notices
319     echo dcPage::notices();
320}
321
322if (!$core_media_writable) {
323     dcPage::warning(__('You do not have sufficient permissions to write to this folder.'));
324}
325
326if (!empty($_GET['mkdok'])) {
327     dcPage::success(__('Directory has been successfully created.'));
328}
329
330if (!empty($_GET['upok'])) {
331     dcPage::success(__('Files have been successfully uploaded.'));
332}
333
334if (!empty($_GET['rmfok'])) {
335     dcPage::success(__('File has been successfully removed.'));
336}
337
338if (!empty($_GET['rmdok'])) {
339     dcPage::success(__('Directory has been successfully removed.'));
340}
341
342if (!empty($_GET['rebuildok'])) {
343     dcPage::success(__('Directory has been successfully rebuilt.'));
344}
345
346if (!empty($_GET['unzipok'])) {
347     dcPage::success(__('Zip file has been successfully extracted.'));
348}
349
350if (!$dir) {
351     call_user_func($close_f);
352     exit;
353}
354
355if ($post_id) {
356     echo '<div class="form-note info"><p>'.sprintf(__('Choose a file to attach to entry %s by clicking on %s.'),
357          '<a href="'.$core->getPostAdminURL($post_type,$post_id).'">'.html::escapeHTML($post_title).'</a>',
358          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</p></div>';
359}
360if ($popup) {
361     echo '<div class="info"><p>'.sprintf(__('Choose a file to insert into entry by clicking on %s.'),
362          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</p></div>';
363}
364
365// Remove hidden directories (unless DC_SHOW_HIDDEN_DIRS is set to true)
366if (!defined('DC_SHOW_HIDDEN_DIRS') || (DC_SHOW_HIDDEN_DIRS == false)) {
367     for ($i = count($dir['dirs']) - 1; $i >= 0; $i--) {
368          if ($dir['dirs'][$i]->d) {
369               if (strpos($dir['dirs'][$i]->relname,'.') !== false) {
370                    unset($dir['dirs'][$i]);
371               }
372          }
373     }
374}
375$items = array_values(array_merge($dir['dirs'],$dir['files']));
376
377$fmt_form_media = '<form action="media.php" method="post" id="form-medias">'.
378     '<div class="files-group">%s</div>'.
379     '<p class="hidden">'.$core->formNonce() . form::hidden(array('d'),$d).'</p>';
380
381if (!$popup) {
382     $fmt_form_media .=
383     '<div class="medias-delete%s">'.
384     '<p class="checkboxes-helpers"></p>'.
385     '<p><input type="submit" class="delete" name="delete_medias" value="'.__('Remove selected medias').'"/></p>'.
386     '</div>';
387}
388$fmt_form_media .=
389     '</form>';
390
391echo '<div class="media-list">';
392if (count($items) == 0)
393{
394     echo
395     '<p>'.__('No file.').'</p>'.
396     sprintf($fmt_form_media,'',' hide'); // need for jsUpload to append new media
397}
398else
399{
400     $pager = new dcPager($page,count($items),$nb_per_page,10);
401
402     echo
403     '<form action="media.php" method="get" id="filters-form">'.
404     '<p class="two-boxes"><label for="file_sort" class="classic">'.__('Sort files:').'</label> '.
405     form::combo('file_sort',$sort_combo,$file_sort).'</p>'.
406     '<p class="two-boxes"><label for="nb_per_page" class="classic">'.__('Number of elements displayed per page:').'</label> '.
407     form::field('nb_per_page',5,3,(integer) $nb_per_page).' '.
408     '<input type="submit" value="'.__('OK').'" />'.
409     form::hidden(array('popup'),$popup).
410     form::hidden(array('post_id'),$post_id).
411     '</p>'.
412     '</form>'.
413     $pager->getLinks();
414
415     $dgroup = '';
416     $fgroup = '';
417     for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++,$j++)
418     {
419          if ($items[$i]->d) {
420               $dgroup .= mediaItemLine($items[$i],$j);
421          } else {
422               $fgroup .= mediaItemLine($items[$i],$j);
423          }
424     }
425
426     echo
427     ($dgroup != '' ? '<div class="folders-group">'.$dgroup.'</div>' : '').
428     sprintf($fmt_form_media,$fgroup,'');
429
430     echo $pager->getLinks();
431}
432if (!isset($pager)) {
433     echo
434     '<p class="clear"></p>';
435}
436echo
437'</div>';
438
439if ($core_media_writable || $core_media_archivable) {
440     echo
441     '<div class="vertical-separator">'.
442     '<h3 class="out-of-screen-if-js">'.sprintf(__('In %s:'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h3>';
443}
444
445$core_media_archivable = $core->auth->check('media_admin',$core->blog->id) &&
446     !(count($items) == 0 || (count($items) == 1 && $items[0]->parent));
447
448if ($core_media_writable || $core_media_archivable) {
449     echo
450     '<div class="two-boxes odd">';
451
452     # Create directory
453     if ($core_media_writable)
454     {
455          echo
456          '<form action="'.html::escapeURL($page_url).'" method="post" class="fieldset">'.
457          '<div id="new-dir-f">'.
458          '<h4 class="pretty-title">'.__('Create new directory').'</h4>'.
459          $core->formNonce().
460          '<p><label for="newdir">'.__('Directory Name:').'</label>'.
461          form::field(array('newdir','newdir'),35,255).'</p>'.
462          '<p><input type="submit" value="'.__('Create').'" />'.
463          form::hidden(array('d'),html::escapeHTML($d)).'</p>'.
464          '</div>'.
465          '</form>';
466     }
467
468     # Get zip directory
469     if ($core_media_archivable && !$popup)
470     {
471          echo
472          '<div class="fieldset">'.
473          '<h4 class="pretty-title">'.sprintf(__('Backup content of %s'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h4>'.
474          '<p><a class="button submit" href="'.html::escapeURL($page_url).'&amp;zipdl=1">'.
475          __('Download zip file').'</a></p>'.
476          '</div>';
477     }
478
479     echo
480     '</div>';
481}
482
483if ($core_media_writable)
484{
485     echo
486     '<div class="two-boxes fieldset even">';
487     if ($user_ui_enhanceduploader) {
488          echo
489          '<div class="enhanced_uploader">';
490     } else {
491          echo
492          '<div>';
493     }
494
495     echo
496     '<h4>'.__('Add files').'</h4>'.
497     '<p>'.__('Please take care to publish media that you own and that are not protected by copyright.').'</p>'.
498     '<form id="fileupload" action="'.html::escapeURL($page_url).'" method="post" enctype="multipart/form-data" aria-disabled="false">'.
499     '<p>'.form::hidden(array('MAX_FILE_SIZE'),DC_MAX_UPLOAD_SIZE).
500     $core->formNonce().'</p>'.
501     '<div class="fileupload-ctrl"><p class="queue-message"></p><ul class="files"></ul></div>';
502
503     echo
504     '<div class="fileupload-buttonbar clear">';
505
506     echo
507     '<p><label for="upfile">'.'<span class="add-label one-file">'.__('Choose file').'</span>'.'</label>'.
508     '<button class="button choose_files">'.__('Choose files').'</button>'.
509     '<input type="file" id="upfile" name="upfile[]"'.($user_ui_enhanceduploader?' multiple="mutiple"':'').' data-url="'.html::escapeURL($page_url).'" /></p>';
510
511     echo
512     '<p class="max-sizer form-note">&nbsp;'.__('Maximum file size allowed:').' '.files::size(DC_MAX_UPLOAD_SIZE).'</p>';
513
514     echo
515     '<p class="one-file"><label for="upfiletitle">'.__('Title:').'</label>'.form::field(array('upfiletitle','upfiletitle'),35,255).'</p>'.
516     '<p class="one-file"><label for="upfilepriv" class="classic">'.__('Private').'</label> '.
517     form::checkbox(array('upfilepriv','upfilepriv'),1).'</p>';
518
519     if (!$user_ui_enhanceduploader) {
520          echo
521          '<p class="one-file form-help info">'.__('To send several files at the same time, you can activate the enhanced uploader in').
522          ' <a href="preferences.php?tab=user-options">'.__('My preferences').'</a></p>';
523     }
524
525     echo
526     '<p class="clear"><button class="button clean">'.__('Refresh').'</button>'.
527     '<input class="button cancel one-file" type="reset" value="'.__('Clear all').'"/>'.
528     '<input class="button start" type="submit" value="'.__('Upload').'"/></p>'.
529     '</div>';
530
531     echo
532     '<p style="clear:both;">'.form::hidden(array('d'),$d).'</p>'.
533     '</form>'.
534     '</div>'.
535     '</div>';
536}
537
538# Empty remove form (for javascript actions)
539echo
540'<form id="media-remove-hide" action="'.html::escapeURL($page_url).'" method="post" class="hidden">'.
541'<div>'.
542form::hidden('rmyes',1).form::hidden('d',html::escapeHTML($d)).
543form::hidden('remove','').
544$core->formNonce().
545'</div>'.
546'</form>';
547
548if ($core_media_writable || $core_media_archivable) {
549     echo
550     '</div>';
551}
552
553if (!$popup) {
554     echo '<div class="info"><p>'.sprintf(__('Current settings for medias and images are defined in %s'),
555     '<a href="blog_pref.php#medias-settings">'.__('Blog parameters').'</a>').'</p></div>';
556}
557
558call_user_func($close_f);
559
560/* ----------------------------------------------------- */
561function mediaItemLine($f,$i)
562{
563     global $core, $page_url, $popup, $post_id;
564
565     $fname = $f->basename;
566
567     $class = 'media-item media-col-'.($i%2);
568
569     if ($f->d) {
570          $link = html::escapeURL($page_url).'&amp;d='.html::sanitizeURL($f->relname);
571          if ($f->parent) {
572               $fname = '..';
573               $class .= ' media-folder-up';
574          } else {
575               $class .= ' media-folder';
576          }
577     } else {
578          $link = 'media_item.php?id='.$f->media_id.'&amp;popup='.$popup.'&amp;post_id='.$post_id;
579          $link = $core->callBehavior('adminMediaURL',$link);
580     }
581
582     $maxchars = 36;
583     if (strlen($fname) > $maxchars) {
584          $fname = substr($fname, 0, $maxchars-4).'...'.($f->d ? '' : files::getExtension($fname));
585     }
586     $res =
587     '<div class="'.$class.'"><p><a class="media-icon media-link" href="'.$link.'">'.
588     '<img src="'.$f->media_icon.'" alt="" />'.$fname.'</a></p>';
589
590     $lst = '';
591
592     if (!$f->d) {
593          $lst .=
594          '<li>'.$f->media_title.'</li>'.
595          '<li>'.
596          $f->media_dtstr.' - '.
597          files::size($f->size).' - '.
598          '<a href="'.$f->file_url.'">'.__('open').'</a>'.
599          '</li>';
600     }
601
602     $act = '';
603
604     if ($post_id && !$f->d) {
605          $act .=
606          '<a class="attach-media" title="'.__('Attach this file to entry').'" href="post_media.php?media_id='.$f->media_id.
607          '&amp;post_id='.$post_id.'&amp;attach=1">'.
608          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'"/>'.
609          '</a>';
610     }
611
612     if ($popup && !$f->d) {
613          $act .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Insert this file into entry').'" '.
614          'title="'.__('Insert this file into entry').'" /></a> ';
615     }
616
617     if ($f->del) {
618          if (!$popup && !$f->d) {
619               $act .= form::checkbox(array('medias[]', 'media_'.rawurlencode($f->basename)),rawurlencode($f->basename));
620          } else {
621               $act .= '<a class="media-remove" '.
622               'href="'.html::escapeURL($page_url).'&amp;d='.
623               rawurlencode($GLOBALS['d']).'&amp;remove='.rawurlencode($f->basename).'">'.
624               '<img src="images/trash.png" alt="'.__('Delete').'" title="'.__('delete').'" /></a>';
625          }
626     }
627
628     $lst .= ($act != '' ? '<li class="media-action">&nbsp;'.$act.'</li>' : '');
629
630     if ($f->type == 'audio/mpeg3') {
631          $lst .= '<li>'.dcMedia::mp3player($f->file_url,'index.php?pf=player_mp3.swf').'</li>';
632     }
633
634     $res .=   ($lst != '' ? '<ul>'.$lst.'</ul>' : '');
635
636     $res .= '</div>';
637
638     return $res;
639}
Note: See TracBrowser for help on using the repository browser.

Sites map