Dotclear

source: admin/media.php @ 500:f88db2e809f4

Revision 500:f88db2e809f4, 13.4 KB checked in by kozlika, 13 years ago (diff)

First step for #1247. Il faudra revenir sur les pages media.php, permissions.php, plugins/antispam/index.php (la couleur on verra après ; pour l'instant c'est très voyant, très pratique pour bosser et aussi très gai, na !)

Dans ce commit aussi : réorganisation de la feuille de style pour s'y retrouver plus facilement.

Line 
1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
6# Copyright (c) 2003-2011 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/* Upload backend
14-------------------------------------------------------- */
15if (!empty($_POST['swfupload']))
16{
17     header('content-type: text/plain');
18     try
19     {
20          if (empty($_POST['sess_id']) || empty($_POST['sess_uid'])) {
21               throw new Exception('No credentials.');
22          }
23          define('DC_AUTH_SESS_ID',$_POST['sess_id']);
24          define('DC_AUTH_SESS_UID',$_POST['sess_uid']);
25         
26          require dirname(__FILE__).'/../inc/admin/prepend.php';
27         
28          if (!$core->auth->check('media,media_admin',$core->blog->id)) {
29               throw new Exception('Permission denied.');
30          }
31         
32          $d = isset($_POST['d']) ? $_POST['d'] : null;
33          $core->media = new dcMedia($core);
34          $core->media->chdir($d);
35          $core->media->getDir();
36          $dir =& $core->media->dir;
37         
38          if (empty($_FILES['Filedata'])) {
39               throw new Exception('No file to upload.');
40          }
41         
42          files::uploadStatus($_FILES['Filedata']);
43          $core->media->uploadFile($_FILES['Filedata']['tmp_name'],$_FILES['Filedata']['name']);
44         
45          echo 'ok';
46     }
47     catch (Exception $e) {
48          echo __('Error:').' '.__($e->getMessage());
49     }
50     exit;
51}
52
53
54/* HTML page
55-------------------------------------------------------- */
56require dirname(__FILE__).'/../inc/admin/prepend.php';
57
58dcPage::check('media,media_admin');
59
60$post_id = !empty($_GET['post_id']) ? (integer) $_GET['post_id'] : null;
61if ($post_id) {
62     $post = $core->blog->getPosts(array('post_id'=>$post_id,'post_type'=>''));
63     if ($post->isEmpty()) {
64          $post_id = null;
65     }
66     $post_title = $post->post_title;
67     $post_type = $post->post_type;
68     unset($post);
69}
70$d = isset($_REQUEST['d']) ? $_REQUEST['d'] : null;
71$dir = null;
72
73$page = !empty($_GET['page']) ? $_GET['page'] : 1;
74$nb_per_page =  30;
75
76# We are on home not comming from media manager
77if ($d === null && isset($_SESSION['media_manager_dir'])) {
78     # We get session information
79     $d = $_SESSION['media_manager_dir'];
80}
81
82if (!isset($_GET['page']) && isset($_SESSION['media_manager_page'])) {
83     $page = $_SESSION['media_manager_page'];
84}
85
86# We set session information about directory and page
87if ($d) {
88     $_SESSION['media_manager_dir'] = $d;
89} else {
90     unset($_SESSION['media_manager_dir']);
91}
92if ($page != 1) {
93     $_SESSION['media_manager_page'] = $page;
94} else {
95     unset($_SESSION['media_manager_page']);
96}
97
98# Sort combo
99$sort_combo = array(
100     __('By names, in ascending order') => 'name-asc',
101     __('By names, in descending order') => 'name-desc',
102     __('By dates, in ascending order') => 'date-asc',
103     __('By dates, in descending order') => 'date-desc'
104);
105
106if (!empty($_GET['file_sort']) && in_array($_GET['file_sort'],$sort_combo)) {
107     $_SESSION['media_file_sort'] = $_GET['file_sort'];
108}
109$file_sort = !empty($_SESSION['media_file_sort']) ? $_SESSION['media_file_sort'] : null;
110
111$popup = (integer) !empty($_GET['popup']);
112
113$page_url = 'media.php?popup='.$popup.'&post_id='.$post_id;
114
115if ($popup) {
116     $open_f = array('dcPage','openPopup');
117     $close_f = array('dcPage','closePopup');
118} else {
119     $open_f = array('dcPage','open');
120     $close_f = create_function('',"dcPage::helpBlock('core_media'); dcPage::close();");
121}
122
123$core_media_writable = false;
124try {
125     $core->media = new dcMedia($core);
126     if ($file_sort) {
127          $core->media->setFileSort($file_sort);
128     }
129     $core->media->chdir($d);
130     $core->media->getDir();
131     $core_media_writable = $core->media->writable();
132     $dir =& $core->media->dir;
133     if  (!$core_media_writable) {
134          throw new Exception('you do not have sufficient permissions to write to this folder: ');
135     }
136} catch (Exception $e) {
137     $core->error->add($e->getMessage());
138}
139
140# Zip download
141if (!empty($_GET['zipdl']) && $core->auth->check('media_admin',$core->blog->id))
142{
143     try
144     {
145          @set_time_limit(300);
146          $fp = fopen('php://output','wb');
147          $zip = new fileZip($fp);
148          $zip->addExclusion('#(^|/).(.*?)_(m|s|sq|t).jpg$#');
149          $zip->addDirectory($core->media->root.'/'.$d,'',true);
150         
151          header('Content-Disposition: attachment;filename='.($d ? $d : 'media').'.zip');
152          header('Content-Type: application/x-zip');
153          $zip->write();
154          unset($zip);
155          exit;
156     }
157     catch (Exception $e)
158     {
159          $core->error->add($e->getMessage());
160     }
161}
162
163# New directory
164if ($dir && !empty($_POST['newdir']))
165{
166     try {
167          $core->media->makeDir($_POST['newdir']);
168          http::redirect($page_url.'&d='.rawurlencode($d).'&mkdok=1');
169     } catch (Exception $e) {
170          $core->error->add($e->getMessage());
171     }
172}
173
174# Adding a file
175if ($dir && !empty($_FILES['upfile']))
176{
177     try
178     {
179          files::uploadStatus($_FILES['upfile']);
180         
181          $f_title = (isset($_POST['upfiletitle']) ? $_POST['upfiletitle'] : '');
182          $f_private = (isset($_POST['upfilepriv']) ? $_POST['upfilepriv'] : false);
183         
184          $core->media->uploadFile($_FILES['upfile']['tmp_name'],$_FILES['upfile']['name'],$f_title,$f_private);
185          http::redirect($page_url.'&d='.rawurlencode($d).'&upok=1');
186     }
187     catch (Exception $e)
188     {
189          $core->error->add($e->getMessage());
190     }
191}
192
193
194# Removing item
195if ($dir && !empty($_POST['rmyes']) && !empty($_POST['remove']))
196{
197     $_POST['remove'] = rawurldecode($_POST['remove']);
198     
199     try {
200          $core->media->removeItem($_POST['remove']);
201          http::redirect($page_url.'&d='.rawurlencode($d).'&rmfok=1');
202     } catch (Exception $e) {
203          $core->error->add($e->getMessage());
204     }
205}
206
207# Rebuild directory
208if ($dir && $core->auth->isSuperAdmin() && !empty($_POST['rebuild']))
209{
210     try {
211          $core->media->rebuild($d);
212          http::redirect($page_url.'&d='.rawurlencode($d).'&rebuildok=1');
213     } catch (Exception $e) {
214          $core->error->add($e->getMessage());
215     }
216}
217
218
219# DISPLAY confirm page for rmdir & rmfile
220if ($dir && !empty($_GET['remove']))
221{
222     call_user_func($open_f,__('Media manager'));
223     
224     echo '<h2>'.html::escapeHTML($core->blog->name).' &rsaquo; '.__('Media manager').' &rsaquo; <span class="page-title">'.__('confirm removal').'</span></h2>';
225     
226     echo
227     '<form action="'.html::escapeURL($page_url).'" method="post">'.
228     '<p>'.sprintf(__('Are you sure you want to remove %s?'),
229     html::escapeHTML($_GET['remove'])).'</p>'.
230     '<p><input type="submit" value="'.__('cancel').'" /> '.
231     ' &nbsp; <input type="submit" name="rmyes" value="'.__('yes').'" />'.
232     form::hidden('d',$d).
233     $core->formNonce().
234     form::hidden('remove',html::escapeHTML($_GET['remove'])).'</p>'.
235     '</form>';
236     
237     call_user_func($close_f);
238     exit;
239}
240
241/* DISPLAY Main page
242-------------------------------------------------------- */
243$core->auth->user_prefs->addWorkspace('interface');
244$user_ui_enhanceduploader = $core->auth->user_prefs->interface->enhanceduploader;
245
246call_user_func($open_f,__('Media manager'),
247     '<script type="text/javascript">'."\n".
248     "//<![CDATA["."\n".
249     dcPage::jsVar('dotclear.candyUpload_force_init',$user_ui_enhanceduploader)."\n".
250     "//]]>".
251     "</script>".
252     dcPage::jsLoad('js/_media.js').
253     (($user_ui_enhanceduploader && $core_media_writable) ? dcPage::jsCandyUpload(array('d='.$d)) : '')
254     );
255
256if (!empty($_GET['mkdok'])) {
257     echo '<p class="message">'.__('Directory has been successfully created.').'</p>';
258}
259
260if (!empty($_GET['upok'])) {
261     echo '<p class="message">'.__('Files have been successfully uploaded.').'</p>';
262}
263
264if (!empty($_GET['rmfok'])) {
265     echo '<p class="message">'.__('File has been successfully removed.').'</p>';
266}
267
268if (!empty($_GET['rmdok'])) {
269     echo '<p class="message">'.__('Directory has been successfully removed.').'</p>';
270}
271
272if (!empty($_GET['rebuildok'])) {
273     echo '<p class="message">'.__('Directory has been successfully rebuilt.').'</p>';
274}
275
276if (!empty($_GET['unzipok'])) {
277     echo '<p class="message">'.__('Zip file has been successfully extracted.').'</p>';
278}
279
280echo '<h2>'.html::escapeHTML($core->blog->name).' &rsaquo; <a href="'.html::escapeURL($page_url.'&d=').'">'.__('Media manager').'</a>'.
281' / '.(isset($core->media) ? $core->media->breadCrumb(html::escapeURL($page_url).'&amp;d=%s') : '').'</h2>';
282
283if (!$dir) {
284     call_user_func($close_f);
285     exit;
286}
287
288if ($post_id) {
289     echo '<p><strong>'.sprintf(__('Choose a file to attach to entry %s by clicking on %s.'),
290     '<a href="'.$core->getPostAdminURL($post_type,$post_id).'">'.html::escapeHTML($post_title).'</a>',
291     '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</strong></p>';
292}
293if ($popup) {
294     echo '<p><strong>'.sprintf(__('Choose a file to insert into entry by clicking on %s.'),
295     '<img src="images/plus.png" alt="'.__('Attach this file to entry').'" />').'</strong></p>';
296}
297
298
299$items = array_values(array_merge($dir['dirs'],$dir['files']));
300if (count($items) == 0)
301{
302     echo '<p><strong>'.__('No file.').'</strong></p>';
303}
304else
305{
306     $pager = new pager($page,count($items),$nb_per_page,10);
307     $pager->html_prev = __($pager->html_prev);
308     $pager->html_next = __($pager->html_next);
309     
310     echo
311     '<form action="media.php" method="get">'.
312     '<p><label for="file_sort" class="classic">'.__('Sort files:').' '.
313     form::combo('file_sort',$sort_combo,$file_sort).'</label>'.
314     form::hidden(array('popup'),$popup).
315     form::hidden(array('post_id'),$post_id).
316     '<input type="submit" value="'.__('ok').'" /></p>'.
317     '</form>'.
318     
319     '<div class="media-list">'.
320     '<p>'.__('Page(s)').' : '.$pager->getLinks().'</p>';
321     
322     for ($i=$pager->index_start, $j=0; $i<=$pager->index_end; $i++, $j++)
323     {
324          echo mediaItemLine($items[$i],$j);
325     }
326     
327     echo
328     '<p class="clear">'.__('Page(s)').' : '.$pager->getLinks().'</p>'.
329     '</div>';
330}
331
332if ($core_media_writable)
333{
334     echo '<div class="two-cols">';
335     
336     echo
337     '<div class="col"><h3 id="add-file">'.__('Add files').'</h3>'.
338     '<p>'.__('Please take care to publish media that you own and that are not protected by copyright.').'</p>'.
339     '<form id="media-upload" class="clear" action="'.html::escapeURL($page_url).'" method="post" enctype="multipart/form-data">'.
340     '<div>'.form::hidden(array('MAX_FILE_SIZE'),DC_MAX_UPLOAD_SIZE).
341     $core->formNonce().'</div>'.
342     '<fieldset id="add-file-f">'.
343     '<p><label for="upfile">'.__('Choose a file:').
344     ' ('.sprintf(__('Maximum size %s'),files::size(DC_MAX_UPLOAD_SIZE)).')'.
345     '<input type="file" id="upfile" name="upfile" size="20" />'.
346     '</label></p>'.
347     '<p><label for="upfiletitle">'.__('Title:').form::field(array('upfiletitle','upfiletitle'),35,255).'</label></p>'.
348     '<p><label for="upfilepriv" class="classic">'.form::checkbox(array('upfilepriv','upfilepriv'),1).' '.
349     __('Private').'</label></p>'.
350     '<p class="form-help info">'.__('To send several files at the same time, you can activate the enhanced uploader in').
351     '<a href="preferences.php?tab=user-options"> '.__('My preferences').'</a></p>'.
352     '<p><input type="submit" value="'.__('send').'" />'.
353     form::hidden(array('d'),$d).'</p>'.
354     '</fieldset>'.
355     '</form>'.
356     '</div>';
357     
358     echo
359     '<div class="col"><h3 id="new-dir">'.__('New directory').'</h3>'.
360     '<form class="clear" action="'.html::escapeURL($page_url).'" method="post">'.
361     '<fieldset id="new-dir-f">'.
362     $core->formNonce().
363     '<p><label for="newdir">'.__('Directory Name:').
364     form::field(array('newdir','newdir'),35,255).'</label></p>'.
365     '<p><input type="submit" value="'.__('Save').'" />'.
366     form::hidden(array('d'),html::escapeHTML($d)).'</p>'.
367     '</fieldset>'.
368     '</form></div>';
369     
370     echo '</div>';
371}
372
373# Empty remove form (for javascript actions)
374echo
375'<form id="media-remove-hide" action="'.html::escapeURL($page_url).'" method="post"><div class="clear">'.
376form::hidden('rmyes',1).form::hidden('d',html::escapeHTML($d)).
377form::hidden('remove','').
378$core->formNonce().
379'</div></form>';
380
381# Get zip directory
382if ($core->auth->check('media_admin',$core->blog->id) && 
383     !(count($items) == 0 || (count($items) == 1 && $items[0]->parent)))
384{
385     echo
386     '<p class="zip-dl"><a href="'.html::escapeURL($page_url).'&amp;zipdl=1">'.
387     __('Download this directory as a zip file').'</a></p>';
388}
389
390call_user_func($close_f);
391
392/* ----------------------------------------------------- */
393function mediaItemLine($f,$i)
394{
395     global $core, $page_url, $popup, $post_id;
396     
397     $fname = $f->basename;
398     
399     if ($f->d) {
400          $link = html::escapeURL($page_url).'&amp;d='.html::sanitizeURL($f->relname);
401          if ($f->parent) {
402               $fname = '..';
403          }
404     } else {
405          $link =
406          'media_item.php?id='.$f->media_id.'&amp;popup='.$popup.'&amp;post_id='.$post_id;
407     }
408     
409     $class = 'media-item media-col-'.($i%2);
410     
411     $res =
412     '<div class="'.$class.'"><a class="media-icon media-link" href="'.$link.'">'.
413     '<img src="'.$f->media_icon.'" alt="" /></a>'.
414     '<ul>'.
415     '<li><a class="media-link" href="'.$link.'">'.$fname.'</a></li>';
416     
417     if (!$f->d) {
418          $res .=
419          '<li>'.$f->media_title.'</li>'.
420          '<li>'.
421          $f->media_dtstr.' - '.
422          files::size($f->size).' - '.
423          '<a href="'.$f->file_url.'">'.__('open').'</a>'.
424          '</li>';
425     }
426     
427     $res .= '<li class="media-action">&nbsp;';
428     
429     if ($post_id && !$f->d) {
430          $res .= '<form action="post_media.php" method="post">'.
431          '<input type="image" src="images/plus.png" alt="'.__('Attach this file to entry').'" '.
432          'title="'.__('Attach this file to entry').'" /> '.
433          form::hidden('media_id',$f->media_id).
434          form::hidden('post_id',$post_id).
435          form::hidden('attach',1).
436          $core->formNonce().
437          '</form>';
438     }
439     
440     if ($popup && !$f->d) {
441          $res .= '<a href="'.$link.'"><img src="images/plus.png" alt="'.__('Insert this file into entry').'" '.
442          'title="'.__('Insert this file into entry').'" /></a> ';
443     }
444     
445     if ($f->del) {
446          $res .= '<a class="media-remove" '.
447          'href="'.html::escapeURL($page_url).'&amp;d='.
448          rawurlencode($GLOBALS['d']).'&amp;remove='.rawurlencode($f->basename).'">'.
449          '<img src="images/trash.png" alt="'.__('delete').'" title="'.__('delete').'" /></a>';
450     }
451     
452     $res .= '</li>';
453     
454     if ($f->type == 'audio/mpeg3') {
455          $res .= '<li>'.dcMedia::mp3player($f->file_url,'index.php?pf=player_mp3.swf').'</li>';
456     }
457     
458     $res .= '</ul></div>';
459     
460     return $res;
461}
462?>
Note: See TracBrowser for help on using the repository browser.

Sites map