Dotclear

source: admin/media.php @ 2099:7af2e5aa15c2

Revision 2099:7af2e5aa15c2, 16.4 KB checked in by franck <carnet.franck.paul@…>, 12 years ago (diff)

Extension should not be search on folder item.

RevLine 
[0]1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
[1179]6# Copyright (c) 2003-2013 Olivier Meunier & Association Dotclear
[0]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) {
[408]21     $post = $core->blog->getPosts(array('post_id'=>$post_id,'post_type'=>''));
[0]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
[1912]32$page = !empty($_GET['page']) ? max(1,(integer) $_GET['page']) : 1;
[2021]33$nb_per_page = ((integer) $core->auth->user_prefs->interface->media_by_page ? (integer) $core->auth->user_prefs->interface->media_by_page : 30);
[0]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'
[1161]63     );
[0]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;
[2090]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}
[0]73
74$popup = (integer) !empty($_GET['popup']);
75
76$page_url = 'media.php?popup='.$popup.'&post_id='.$post_id;
77
78if ($popup) {
79     $open_f = array('dcPage','openPopup');
80     $close_f = array('dcPage','closePopup');
81} else {
82     $open_f = array('dcPage','open');
83     $close_f = create_function('',"dcPage::helpBlock('core_media'); dcPage::close();");
84}
85
86$core_media_writable = false;
87try {
88     $core->media = new dcMedia($core);
89     if ($file_sort) {
90          $core->media->setFileSort($file_sort);
91     }
92     $core->media->chdir($d);
93     $core->media->getDir();
94     $core_media_writable = $core->media->writable();
95     $dir =& $core->media->dir;
96     if  (!$core_media_writable) {
[1725]97//        throw new Exception('you do not have sufficient permissions to write to this folder: ');
[0]98     }
99} catch (Exception $e) {
100     $core->error->add($e->getMessage());
101}
102
103# Zip download
104if (!empty($_GET['zipdl']) && $core->auth->check('media_admin',$core->blog->id))
105{
106     try
107     {
108          @set_time_limit(300);
109          $fp = fopen('php://output','wb');
110          $zip = new fileZip($fp);
111          $zip->addExclusion('#(^|/).(.*?)_(m|s|sq|t).jpg$#');
112          $zip->addDirectory($core->media->root.'/'.$d,'',true);
113         
114          header('Content-Disposition: attachment;filename='.($d ? $d : 'media').'.zip');
115          header('Content-Type: application/x-zip');
116          $zip->write();
117          unset($zip);
118          exit;
119     }
120     catch (Exception $e)
121     {
122          $core->error->add($e->getMessage());
123     }
124}
125
126# New directory
127if ($dir && !empty($_POST['newdir']))
128{
129     try {
130          $core->media->makeDir($_POST['newdir']);
131          http::redirect($page_url.'&d='.rawurlencode($d).'&mkdok=1');
132     } catch (Exception $e) {
133          $core->error->add($e->getMessage());
134     }
135}
136
137# Adding a file
[1159]138if ($dir && !empty($_FILES['upfile'])) {
139  // only one file per request : @see option singleFileUploads in admin/js/jsUpload/jquery.fileupload
[1161]140     $upfile = array('name' => $_FILES['upfile']['name'][0],
141          'type' => $_FILES['upfile']['type'][0],
142          'tmp_name' => $_FILES['upfile']['tmp_name'][0],
143          'error' => $_FILES['upfile']['error'][0],
144          'size' => $_FILES['upfile']['size'][0]
145          );
[1144]146
[1161]147     if (!empty($_SERVER['HTTP_X_REQUESTED_WITH'])) {
148          header('Content-type: application/json');
149          $message = array();
[1144]150
[1161]151          try {
152               files::uploadStatus($upfile);
153               $new_file_id = $core->media->uploadFile($upfile['tmp_name'], $upfile['name']);
[1144]154
[1161]155               $message['files'][] = array('name' => $upfile['name'],
156                    'size' => $upfile['size'],
157                    'html' => mediaItemLine($core->media->getFile($new_file_id), 1)
158                    );
159          } catch (Exception $e) {
160               $message['files'][] = array('name' => $upfile['name'],
[1162]161                    'size' => $upfile['size'],
[1161]162                    'error' => $e->getMessage()
163                    );
164          }
165          echo json_encode($message);
166          exit();
167     } else {
168          try {
169               files::uploadStatus($upfile);
[1159]170
[1161]171               $f_title = (isset($_POST['upfiletitle']) ? $_POST['upfiletitle'] : '');
172               $f_private = (isset($_POST['upfilepriv']) ? $_POST['upfilepriv'] : false);
[1159]173
[1161]174               $core->media->uploadFile($upfile['tmp_name'], $upfile['name'], $f_title, $f_private);
175               http::redirect($page_url.'&d='.rawurlencode($d).'&upok=1');
176          } catch (Exception $e) {
177               $core->error->add($e->getMessage());
178          }
179     }
[0]180}
181
182# Removing item
183if ($dir && !empty($_POST['rmyes']) && !empty($_POST['remove']))
184{
185     $_POST['remove'] = rawurldecode($_POST['remove']);
186     
187     try {
188          $core->media->removeItem($_POST['remove']);
189          http::redirect($page_url.'&d='.rawurlencode($d).'&rmfok=1');
190     } catch (Exception $e) {
191          $core->error->add($e->getMessage());
192     }
193}
194
195# Rebuild directory
196if ($dir && $core->auth->isSuperAdmin() && !empty($_POST['rebuild']))
197{
198     try {
199          $core->media->rebuild($d);
200          http::redirect($page_url.'&d='.rawurlencode($d).'&rebuildok=1');
201     } catch (Exception $e) {
202          $core->error->add($e->getMessage());
203     }
204}
205
206# DISPLAY confirm page for rmdir & rmfile
[947]207if ($dir && !empty($_GET['remove']) && empty($_GET['noconfirm']))
[0]208{
[1358]209     call_user_func($open_f,__('Media manager'),'',
210          dcPage::breadcrumb(
211               array(
212                    html::escapeHTML($core->blog->name) => '',
213                    __('Media manager') => '',
214                    '<span class="page-title">'.__('confirm removal').'</span>' => ''
215               ),!$popup)
216     );
[0]217     
218     echo
219     '<form action="'.html::escapeURL($page_url).'" method="post">'.
220     '<p>'.sprintf(__('Are you sure you want to remove %s?'),
[1161]221          html::escapeHTML($_GET['remove'])).'</p>'.
[557]222     '<p><input type="submit" value="'.__('Cancel').'" /> '.
223     ' &nbsp; <input type="submit" name="rmyes" value="'.__('Yes').'" />'.
[0]224     form::hidden('d',$d).
225     $core->formNonce().
226     form::hidden('remove',html::escapeHTML($_GET['remove'])).'</p>'.
227     '</form>';
228     
229     call_user_func($close_f);
230     exit;
231}
232
233/* DISPLAY Main page
234-------------------------------------------------------- */
[240]235$core->auth->user_prefs->addWorkspace('interface');
236$user_ui_enhanceduploader = $core->auth->user_prefs->interface->enhanceduploader;
237
[1358]238if (!isset($core->media)) {
239     $breadcrumb = dcPage::breadcrumb(
240          array(
241               html::escapeHTML($core->blog->name) => '',
242               '<span class="page-title">'.__('Media manager').'</span>' => ''
243          ),!$popup);
244} else {
245     $breadcrumb_media = $core->media->breadCrumb(html::escapeURL($page_url).'&amp;d=%s','<span class="page-title">%s</span>');
246     if ($breadcrumb_media == '') {
247          $breadcrumb = dcPage::breadcrumb(
248               array(
249                    html::escapeHTML($core->blog->name) => '',
250                    '<span class="page-title">'.__('Media manager').'</span>' => ''
251               ),!$popup);
252     } else {
253          $breadcrumb = dcPage::breadcrumb(
254               array(
255                    html::escapeHTML($core->blog->name) => '',
256                    __('Media manager') => html::escapeURL($page_url.'&d='),
257                    $breadcrumb_media => ''
258               ),!$popup);
259     }
260}
261
[0]262call_user_func($open_f,__('Media manager'),
263     dcPage::jsLoad('js/_media.js').
[1358]264     ($core_media_writable ? dcPage::jsUpload(array('d='.$d)) : ''),
265     $breadcrumb
[240]266     );
[0]267
[1725]268if (!$core_media_writable) {
269     dcPage::warning(__('You do not have sufficient permissions to write to this folder.'));
270}
271
[0]272if (!empty($_GET['mkdok'])) {
[1553]273     dcPage::success(__('Directory has been successfully created.'));
[0]274}
275
276if (!empty($_GET['upok'])) {
[1553]277     dcPage::success(__('Files have been successfully uploaded.'));
[0]278}
279
280if (!empty($_GET['rmfok'])) {
[1553]281     dcPage::success(__('File has been successfully removed.'));
[0]282}
283
284if (!empty($_GET['rmdok'])) {
[1553]285     dcPage::success(__('Directory has been successfully removed.'));
[0]286}
287
288if (!empty($_GET['rebuildok'])) {
[1553]289     dcPage::success(__('Directory has been successfully rebuilt.'));
[0]290}
291
292if (!empty($_GET['unzipok'])) {
[1553]293     dcPage::success(__('Zip file has been successfully extracted.'));
[0]294}
295
296if (!$dir) {
297     call_user_func($close_f);
298     exit;
299}
300
301if ($post_id) {
[1605]302     echo '<p class="form-note info">'.sprintf(__('Choose a file to attach to entry %s by clicking on %s.'),
[1161]303          '<a href="'.$core->getPostAdminURL($post_type,$post_id).'">'.html::escapeHTML($post_title).'</a>',
[1605]304          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</p>';
[0]305}
306if ($popup) {
[2006]307     echo '<div class="info"><p>'.sprintf(__('Choose a file to insert into entry by clicking on %s.'),
308          '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</p></div>';
[0]309}
310
311
312$items = array_values(array_merge($dir['dirs'],$dir['files']));
[1160]313echo '<div class="media-list">';
[0]314if (count($items) == 0)
315{
[1982]316     echo 
317     '<p>'.__('No file.').'</p>'.
318     '<div class="files-group"></div>'; // need for jsUpload to append new media
[0]319}
320else
321{
[1926]322     $pager = new dcPager($page,count($items),$nb_per_page,10);
[0]323     
324     echo
325     '<form action="media.php" method="get">'.
[1399]326     '<p><label for="file_sort" class="classic">'.__('Sort files:').'</label> '.
[2090]327     form::combo('file_sort',$sort_combo,$file_sort).' - '.
328     '<label for="nb_per_page" class="classic">'.__('Number of media displayed per page:').'</label> '.
329     form::field('nb_per_page',5,3,(integer) $nb_per_page).' '.
330     '<input type="submit" value="'.__('OK').'" />'.
[0]331     form::hidden(array('popup'),$popup).
332     form::hidden(array('post_id'),$post_id).
[2090]333     '</p>'.
[0]334     '</form>'.
[1926]335     $pager->getLinks();
[1855]336
337     $dgroup = '';
338     $fgroup = '';
339     for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++,$j++)
[0]340     {
[1855]341          if ($items[$i]->d) {
342               $dgroup .= mediaItemLine($items[$i],$j);
343          } else {
344               $fgroup .= mediaItemLine($items[$i],$j);
345          }
[0]346     }
[1855]347     echo 
348          ($dgroup != '' ? '<div class="folders-group">'.$dgroup.'</div>' : '').
[1952]349          '<div class="files-group">'.$fgroup.'</div>';
[0]350     
[1926]351     echo $pager->getLinks();
[0]352}
[1162]353if (!isset($pager)) {
354     echo
355     '<p class="clear"></p>';
356}
[1160]357echo
[1161]358'</div>';
[1144]359
[1979]360echo
361'<div class="clearfix"><p class="info">'.sprintf(__('Current settings for medias and images are defined in %s'),
362'<a href="blog_pref.php#medias-settings">'.__('Blog parameters').'</a>').'</p></div>';
363
364if ($core_media_writable || $core_media_archivable) {
365     echo
366     '<div class="vertical-separator">'.
367     '<h3 class="out-of-screen-if-js">'.sprintf(__('In %s:'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h3>'; 
368}
369
370$core_media_archivable = $core->auth->check('media_admin',$core->blog->id) && 
371     !(count($items) == 0 || (count($items) == 1 && $items[0]->parent));
372
373if ($core_media_writable || $core_media_archivable) {
374     echo 
375     '<div class="two-boxes odd">';
376
377     # Create directory
378     if ($core_media_writable)
379     {
380          echo
381          '<form action="'.html::escapeURL($page_url).'" method="post" class="fieldset">'.
382          '<div id="new-dir-f">'.
383          '<h4 class="pretty-title">'.__('Create new directory').'</h4>'.
384          $core->formNonce().
385          '<p><label for="newdir">'.__('Directory Name:').'</label>'.
386          form::field(array('newdir','newdir'),35,255).'</p>'.
387          '<p><input type="submit" value="'.__('Create').'" />'.
388          form::hidden(array('d'),html::escapeHTML($d)).'</p>'.
389          '</div>'.
390          '</form>';
391     }
392
393     # Get zip directory
394     if ($core_media_archivable)
395     {
396          echo
397          '<div class="fieldset">'.
398          '<h4 class="pretty-title">'.sprintf(__('Backup content of %s'),($d == '' ? '“'.__('Media manager').'”' : '“'.$d.'”')).'</h4>'.
399          '<p><a class="button submit" href="'.html::escapeURL($page_url).'&amp;zipdl=1">'.
400          __('Download zip file').'</a></p>'.
401          '</div>';
402     }
403
404     echo 
405     '</div>';
406}
407
[0]408if ($core_media_writable)
409{
[1979]410     echo
411     '<div class="two-boxes fieldset">';     
[1161]412     if ($user_ui_enhanceduploader) {
413          echo
[1681]414          '<div class="enhanced_uploader">';
[1161]415     } else {
416          echo
[1681]417          '<div>';
[1161]418     }
[1159]419
[1161]420     echo
[1681]421     '<h4>'.__('Add files').'</h4>'.
[1161]422     '<p>'.__('Please take care to publish media that you own and that are not protected by copyright.').'</p>'.
[1519]423     '<form id="fileupload" action="'.html::escapeURL($page_url).'" method="post" enctype="multipart/form-data" aria-disabled="false">'.
[1450]424     '<p>'.form::hidden(array('MAX_FILE_SIZE'),DC_MAX_UPLOAD_SIZE).
425     $core->formNonce().'</p>'.
426     '<div class="fileupload-ctrl"><p class="queue-message"></p><ul class="files"></ul></div>';
[1159]427
[1161]428     echo
[1519]429     '<div class="fileupload-buttonbar clear">';
[1162]430
431     echo
[1450]432     '<p><label for="upfile">'.'<span class="add-label one-file">'.__('Choose file').'</span>'.'</label>'.
[1852]433     '<button class="button choose_files">'.__('Choose files').'</button>'.
[1450]434     '<input type="file" id="upfile" name="upfile[]"'.($user_ui_enhanceduploader?' multiple="mutiple"':'').' data-url="'.html::escapeURL($page_url).'" /></p>';
[1159]435
[1161]436     echo
[1854]437     '<p class="max-sizer form-note">&nbsp;'.__('Maximum file size allowed:').' '.files::size(DC_MAX_UPLOAD_SIZE).'</p>';
438
439     echo
[1450]440     '<p class="one-file"><label for="upfiletitle">'.__('Title:').'</label>'.form::field(array('upfiletitle','upfiletitle'),35,255).'</p>'.
[1452]441     '<p class="one-file"><label for="upfilepriv" class="classic">'.__('Private').'</label> '.
[1450]442     form::checkbox(array('upfilepriv','upfilepriv'),1).'</p>';
[1159]443
[1161]444     if (!$user_ui_enhanceduploader) {
445          echo
446          '<p class="one-file form-help info">'.__('To send several files at the same time, you can activate the enhanced uploader in').
447          ' <a href="preferences.php?tab=user-options">'.__('My preferences').'</a></p>';
448     }
[1159]449
[1161]450     echo
[1526]451     '<p class="clear"><button class="button clean">'.__('Refresh').'</button>'.
[1183]452     '<input class="button cancel one-file" type="reset" value="'.__('Clear all').'"/>'.
[1450]453     '<input class="button start" type="submit" value="'.__('Upload').'"/></p>'.
[1161]454     '</div>';
[1159]455
[1161]456     echo
[1526]457     '<p style="clear:both;">'.form::hidden(array('d'),$d).'</p>'.
[1161]458     '</form>'.
[1681]459     '</div>'.
460     '</div>';
[1725]461}
[1450]462
[0]463# Empty remove form (for javascript actions)
464echo
[1681]465'<form id="media-remove-hide" action="'.html::escapeURL($page_url).'" method="post" class="hidden">'.
466'<div>'.
[0]467form::hidden('rmyes',1).form::hidden('d',html::escapeHTML($d)).
468form::hidden('remove','').
469$core->formNonce().
[1681]470'</div>'.
471'</form>';
[0]472
[1979]473if ($core_media_writable || $core_media_archivable) {
474     echo 
475     '</div>';
476}
477
[0]478call_user_func($close_f);
479
480/* ----------------------------------------------------- */
481function mediaItemLine($f,$i)
482{
483     global $core, $page_url, $popup, $post_id;
484     
485     $fname = $f->basename;
486     
[1849]487     $class = 'media-item media-col-'.($i%2);
488     
[0]489     if ($f->d) {
490          $link = html::escapeURL($page_url).'&amp;d='.html::sanitizeURL($f->relname);
491          if ($f->parent) {
492               $fname = '..';
[1849]493               $class .= ' media-folder-up';
494          } else {
495               $class .= ' media-folder';
[0]496          }
497     } else {
498          $link =
499          'media_item.php?id='.$f->media_id.'&amp;popup='.$popup.'&amp;post_id='.$post_id;
500     }
501     
[2097]502     $maxchars = 36;
503     if (strlen($fname) > $maxchars) {
[2099]504          $fname = substr($fname, 0, $maxchars-4).'...'.($f->d ? '' : files::getExtension($fname));
[2097]505     }
[0]506     $res =
[1855]507     '<div class="'.$class.'"><p><a class="media-icon media-link" href="'.$link.'">'.
508     '<img src="'.$f->media_icon.'" alt="" />'.$fname.'</a></p>';
509
510     $lst = '';
[0]511     
512     if (!$f->d) {
[1855]513          $lst .=
[0]514          '<li>'.$f->media_title.'</li>'.
515          '<li>'.
516          $f->media_dtstr.' - '.
517          files::size($f->size).' - '.
518          '<a href="'.$f->file_url.'">'.__('open').'</a>'.
519          '</li>';
520     }
521     
[1855]522     $act = '';
[0]523     
524     if ($post_id && !$f->d) {
[1855]525          $act .= 
526          '<form action="post_media.php" method="post">'.
[0]527          '<input type="image" src="images/plus.png" alt="'.__('Attach this file to entry').'" '.
528          'title="'.__('Attach this file to entry').'" /> '.
529          form::hidden('media_id',$f->media_id).
530          form::hidden('post_id',$post_id).
531          form::hidden('attach',1).
532          $core->formNonce().
533          '</form>';
534     }
535     
536     if ($popup && !$f->d) {
[1855]537          $act .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Insert this file into entry').'" '.
[0]538          'title="'.__('Insert this file into entry').'" /></a> ';
539     }
540     
541     if ($f->del) {
[1855]542          $act .= '<a class="media-remove" '.
[0]543          'href="'.html::escapeURL($page_url).'&amp;d='.
544          rawurlencode($GLOBALS['d']).'&amp;remove='.rawurlencode($f->basename).'">'.
[747]545          '<img src="images/trash.png" alt="'.__('Delete').'" title="'.__('delete').'" /></a>';
[0]546     }
547     
[1855]548     $lst .= ($act != '' ? '<li class="media-action">&nbsp;'.$act.'</li>' : '');
[0]549     
550     if ($f->type == 'audio/mpeg3') {
[1855]551          $lst .= '<li>'.dcMedia::mp3player($f->file_url,'index.php?pf=player_mp3.swf').'</li>';
[0]552     }
553     
[1855]554     $res .=   ($lst != '' ? '<ul>'.$lst.'</ul>' : '');
555
556     $res .= '</div>';
[0]557     
558     return $res;
559}
[2097]560?>
Note: See TracBrowser for help on using the repository browser.

Sites map