xref: /dokuwiki/lib/exe/mediamanager.php (revision 1015a57dff9a6f85b8e0534d280aa1e09945a598)
1cf6894dfSAndreas Gohr<?php
2d0a27cb0SAndreas Gohr    if(!defined('DOKU_INC')) define('DOKU_INC',dirname(__FILE__).'/../../');
33df72098SAndreas Gohr    define('DOKU_MEDIAMANAGER',1);
4d00ec455SAndreas Gohr
5a5de816fSAndreas Gohr    // for multi uploader:
6a5de816fSAndreas Gohr    @ini_set('session.use_only_cookies',0);
7a5de816fSAndreas Gohr
83df72098SAndreas Gohr    require_once(DOKU_INC.'inc/init.php');
9a249681dSAndreas Gohr
10361f1762STom N Harris    global $INPUT;
11d186898bSAndreas Gohr    // handle passed message
128108113cSTom N Harris    if($INPUT->str('msg1')) msg(hsc($INPUT->str('msg1')),1);
138108113cSTom N Harris    if($INPUT->str('err')) msg(hsc($INPUT->str('err')),-1);
14d186898bSAndreas Gohr
153df72098SAndreas Gohr    // get namespace to display (either direct or from deletion order)
168108113cSTom N Harris    if($INPUT->str('delete')){
178108113cSTom N Harris        $DEL = cleanID($INPUT->str('delete'));
18a05e297aSAndreas Gohr        $IMG = $DEL;
193df72098SAndreas Gohr        $NS  = getNS($DEL);
208108113cSTom N Harris    }elseif($INPUT->str('edit')){
218108113cSTom N Harris        $IMG = cleanID($INPUT->str('edit'));
223df72098SAndreas Gohr        $NS  = getNS($IMG);
238108113cSTom N Harris    }elseif($INPUT->str('img')){
248108113cSTom N Harris        $IMG = cleanID($INPUT->str('img'));
253df72098SAndreas Gohr        $NS  = getNS($IMG);
263df72098SAndreas Gohr    }else{
278108113cSTom N Harris        $NS = cleanID($INPUT->str('ns'));
28*1015a57dSChristopher Smith        $IMG = null;
293df72098SAndreas Gohr    }
303df72098SAndreas Gohr
31*1015a57dSChristopher Smith    $INFO = mediainfo();
32*1015a57dSChristopher Smith    $AUTH = $INFO['perm'];    // shortcut for historical reasons
33*1015a57dSChristopher Smith
34*1015a57dSChristopher Smith    trigger_event('MEDIAMANAGER_STARTED',$tmp=array());
35*1015a57dSChristopher Smith    session_write_close();  //close session
363df72098SAndreas Gohr
370b34c70fSGina Haeussge    // do not display the manager if user does not have read access
3888a71175SKate Arzamastseva    if($AUTH < AUTH_READ && !$fullscreen) {
390b34c70fSGina Haeussge        header('HTTP/1.0 403 Forbidden');
400b34c70fSGina Haeussge        die($lang['accessdenied']);
410b34c70fSGina Haeussge    }
420b34c70fSGina Haeussge
433df72098SAndreas Gohr    // create the given namespace (just for beautification)
44cc7d0c94SBen Coburn    if($AUTH >= AUTH_UPLOAD) { io_createNamespace("$NS:xxx", 'media'); }
453df72098SAndreas Gohr
46d00ec455SAndreas Gohr    // handle flash upload
4758b091deSAndreas Gohr    if(isset($_FILES['Filedata'])){
48d00ec455SAndreas Gohr        $_FILES['upload'] =& $_FILES['Filedata'];
49d00ec455SAndreas Gohr        $JUMPTO = media_upload($NS,$AUTH);
50d00ec455SAndreas Gohr        if($JUMPTO == false){
51d00ec455SAndreas Gohr            header("HTTP/1.0 400 Bad Request");
52d00ec455SAndreas Gohr            echo 'Upload failed';
53d00ec455SAndreas Gohr        }
54d00ec455SAndreas Gohr        echo 'ok';
55d00ec455SAndreas Gohr        exit;
56d00ec455SAndreas Gohr    }
57d00ec455SAndreas Gohr
58a93e6f85SAndreas Gohr    // give info on PHP catched upload errors
5999766eefSAndreas Gohr    if($_FILES['upload']['error']){
6099766eefSAndreas Gohr        switch($_FILES['upload']['error']){
61a93e6f85SAndreas Gohr            case 1:
62a93e6f85SAndreas Gohr            case 2:
63a93e6f85SAndreas Gohr                msg(sprintf($lang['uploadsize'],
64a93e6f85SAndreas Gohr                    filesize_h(php_to_byte(ini_get('upload_max_filesize')))),-1);
65a93e6f85SAndreas Gohr                break;
66a93e6f85SAndreas Gohr            default:
6799766eefSAndreas Gohr                msg($lang['uploadfail'].' ('.$_FILES['upload']['error'].')',-1);
6899766eefSAndreas Gohr        }
6999766eefSAndreas Gohr        unset($_FILES['upload']);
70a93e6f85SAndreas Gohr    }
71d00ec455SAndreas Gohr
723df72098SAndreas Gohr    // handle upload
733df72098SAndreas Gohr    if($_FILES['upload']['tmp_name']){
743df72098SAndreas Gohr        $JUMPTO = media_upload($NS,$AUTH);
757b877f51SAndreas Gohr        if($JUMPTO) $NS = getNS($JUMPTO);
763df72098SAndreas Gohr    }
773df72098SAndreas Gohr
783df72098SAndreas Gohr    // handle meta saving
798108113cSTom N Harris    if($IMG && @array_key_exists('save', $INPUT->arr('do'))){
808108113cSTom N Harris        $JUMPTO = media_metasave($IMG,$AUTH,$INPUT->arr('meta'));
81d9162c6cSKate Arzamastseva    }
82d9162c6cSKate Arzamastseva
838108113cSTom N Harris    if($IMG && ($INPUT->str('mediado') == 'save' || @array_key_exists('save', $INPUT->arr('mediado')))) {
848108113cSTom N Harris        $JUMPTO = media_metasave($IMG,$AUTH,$INPUT->arr('meta'));
853df72098SAndreas Gohr    }
863df72098SAndreas Gohr
878108113cSTom N Harris    if ($INPUT->int('rev') && $conf['mediarevisions']) $REV = $INPUT->int('rev');
889c1bd4bcSKate Arzamastseva
898108113cSTom N Harris    if($INPUT->str('mediado') == 'restore' && $conf['mediarevisions']){
908108113cSTom N Harris        $JUMPTO = media_restore($INPUT->str('image'), $REV, $AUTH);
919c1bd4bcSKate Arzamastseva    }
929c1bd4bcSKate Arzamastseva
933df72098SAndreas Gohr    // handle deletion
943df72098SAndreas Gohr    if($DEL) {
9587229c84SAdrian Lang        $res = 0;
9687229c84SAdrian Lang        if(checkSecurityToken()) {
9787229c84SAdrian Lang            $res = media_delete($DEL,$AUTH);
98666cdec5SMichael Klier        }
9987229c84SAdrian Lang        if ($res & DOKU_MEDIA_DELETED) {
10087229c84SAdrian Lang            $msg = sprintf($lang['deletesucc'], noNS($DEL));
1017d7ab775SKate Arzamastseva            if ($res & DOKU_MEDIA_EMPTY_NS && !$fullscreen) {
10287229c84SAdrian Lang                // current namespace was removed. redirecting to root ns passing msg along
10387229c84SAdrian Lang                send_redirect(DOKU_URL.'lib/exe/mediamanager.php?msg1='.
1048108113cSTom N Harris                        rawurlencode($msg).'&edid='.$INPUT->str('edid'));
10587229c84SAdrian Lang            }
10687229c84SAdrian Lang            msg($msg,1);
10787229c84SAdrian Lang        } elseif ($res & DOKU_MEDIA_INUSE) {
108666cdec5SMichael Klier            if(!$conf['refshow']) {
109d5b31577SChristian Marg                msg(sprintf($lang['mediainuse'],noNS($DEL)),0);
110666cdec5SMichael Klier            }
11187229c84SAdrian Lang        } else {
11287229c84SAdrian Lang            msg(sprintf($lang['deletefail'],noNS($DEL)),-1);
113666cdec5SMichael Klier        }
1143df72098SAndreas Gohr    }
1153df72098SAndreas Gohr    // finished - start output
116d9162c6cSKate Arzamastseva
11788a71175SKate Arzamastseva    if (!$fullscreen) {
1183df72098SAndreas Gohr        header('Content-Type: text/html; charset=utf-8');
1193df72098SAndreas Gohr        include(template('mediamanager.php'));
120d9162c6cSKate Arzamastseva    }
121365be586SAndreas Gohr
122365be586SAndreas Gohr/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
123