xref: /dokuwiki/lib/exe/mediamanager.php (revision 8108113c244529ec54f11271a6a15e3d1e0a048f)
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
10a249681dSAndreas Gohr    trigger_event('MEDIAMANAGER_STARTED',$tmp=array());
113df72098SAndreas Gohr    session_write_close();  //close session
123df72098SAndreas Gohr
13d186898bSAndreas Gohr    // handle passed message
14*8108113cSTom N Harris    if($INPUT->str('msg1')) msg(hsc($INPUT->str('msg1')),1);
15*8108113cSTom N Harris    if($INPUT->str('err')) msg(hsc($INPUT->str('err')),-1);
16d186898bSAndreas Gohr
173df72098SAndreas Gohr
183df72098SAndreas Gohr    // get namespace to display (either direct or from deletion order)
19*8108113cSTom N Harris    if($INPUT->str('delete')){
20*8108113cSTom N Harris        $DEL = cleanID($INPUT->str('delete'));
21a05e297aSAndreas Gohr        $IMG = $DEL;
223df72098SAndreas Gohr        $NS  = getNS($DEL);
23*8108113cSTom N Harris    }elseif($INPUT->str('edit')){
24*8108113cSTom N Harris        $IMG = cleanID($INPUT->str('edit'));
253df72098SAndreas Gohr        $NS  = getNS($IMG);
26*8108113cSTom N Harris    }elseif($INPUT->str('img')){
27*8108113cSTom N Harris        $IMG = cleanID($INPUT->str('img'));
283df72098SAndreas Gohr        $NS  = getNS($IMG);
293df72098SAndreas Gohr    }else{
30*8108113cSTom N Harris        $NS = cleanID($INPUT->str('ns'));
313df72098SAndreas Gohr    }
323df72098SAndreas Gohr
333df72098SAndreas Gohr    // check auth
343df72098SAndreas Gohr    $AUTH = auth_quickaclcheck("$NS:*");
353df72098SAndreas Gohr
360b34c70fSGina Haeussge    // do not display the manager if user does not have read access
3788a71175SKate Arzamastseva    if($AUTH < AUTH_READ && !$fullscreen) {
380b34c70fSGina Haeussge        header('HTTP/1.0 403 Forbidden');
390b34c70fSGina Haeussge        die($lang['accessdenied']);
400b34c70fSGina Haeussge    }
410b34c70fSGina Haeussge
423df72098SAndreas Gohr    // create the given namespace (just for beautification)
43cc7d0c94SBen Coburn    if($AUTH >= AUTH_UPLOAD) { io_createNamespace("$NS:xxx", 'media'); }
443df72098SAndreas Gohr
45d00ec455SAndreas Gohr    // handle flash upload
4658b091deSAndreas Gohr    if(isset($_FILES['Filedata'])){
47d00ec455SAndreas Gohr        $_FILES['upload'] =& $_FILES['Filedata'];
48d00ec455SAndreas Gohr        $JUMPTO = media_upload($NS,$AUTH);
49d00ec455SAndreas Gohr        if($JUMPTO == false){
50d00ec455SAndreas Gohr            header("HTTP/1.0 400 Bad Request");
51d00ec455SAndreas Gohr            echo 'Upload failed';
52d00ec455SAndreas Gohr        }
53d00ec455SAndreas Gohr        echo 'ok';
54d00ec455SAndreas Gohr        exit;
55d00ec455SAndreas Gohr    }
56d00ec455SAndreas Gohr
57a93e6f85SAndreas Gohr    // give info on PHP catched upload errors
5899766eefSAndreas Gohr    if($_FILES['upload']['error']){
5999766eefSAndreas Gohr        switch($_FILES['upload']['error']){
60a93e6f85SAndreas Gohr            case 1:
61a93e6f85SAndreas Gohr            case 2:
62a93e6f85SAndreas Gohr                msg(sprintf($lang['uploadsize'],
63a93e6f85SAndreas Gohr                    filesize_h(php_to_byte(ini_get('upload_max_filesize')))),-1);
64a93e6f85SAndreas Gohr                break;
65a93e6f85SAndreas Gohr            default:
6699766eefSAndreas Gohr                msg($lang['uploadfail'].' ('.$_FILES['upload']['error'].')',-1);
6799766eefSAndreas Gohr        }
6899766eefSAndreas Gohr        unset($_FILES['upload']);
69a93e6f85SAndreas Gohr    }
70d00ec455SAndreas Gohr
713df72098SAndreas Gohr    // handle upload
723df72098SAndreas Gohr    if($_FILES['upload']['tmp_name']){
733df72098SAndreas Gohr        $JUMPTO = media_upload($NS,$AUTH);
747b877f51SAndreas Gohr        if($JUMPTO) $NS = getNS($JUMPTO);
753df72098SAndreas Gohr    }
763df72098SAndreas Gohr
773df72098SAndreas Gohr    // handle meta saving
78*8108113cSTom N Harris    if($IMG && @array_key_exists('save', $INPUT->arr('do'))){
79*8108113cSTom N Harris        $JUMPTO = media_metasave($IMG,$AUTH,$INPUT->arr('meta'));
80d9162c6cSKate Arzamastseva    }
81d9162c6cSKate Arzamastseva
82*8108113cSTom N Harris    if($IMG && ($INPUT->str('mediado') == 'save' || @array_key_exists('save', $INPUT->arr('mediado')))) {
83*8108113cSTom N Harris        $JUMPTO = media_metasave($IMG,$AUTH,$INPUT->arr('meta'));
843df72098SAndreas Gohr    }
853df72098SAndreas Gohr
86*8108113cSTom N Harris    if ($INPUT->int('rev') && $conf['mediarevisions']) $REV = $INPUT->int('rev');
879c1bd4bcSKate Arzamastseva
88*8108113cSTom N Harris    if($INPUT->str('mediado') == 'restore' && $conf['mediarevisions']){
89*8108113cSTom N Harris        $JUMPTO = media_restore($INPUT->str('image'), $REV, $AUTH);
909c1bd4bcSKate Arzamastseva    }
919c1bd4bcSKate Arzamastseva
923df72098SAndreas Gohr    // handle deletion
933df72098SAndreas Gohr    if($DEL) {
9487229c84SAdrian Lang        $res = 0;
9587229c84SAdrian Lang        if(checkSecurityToken()) {
9687229c84SAdrian Lang            $res = media_delete($DEL,$AUTH);
97666cdec5SMichael Klier        }
9887229c84SAdrian Lang        if ($res & DOKU_MEDIA_DELETED) {
9987229c84SAdrian Lang            $msg = sprintf($lang['deletesucc'], noNS($DEL));
1007d7ab775SKate Arzamastseva            if ($res & DOKU_MEDIA_EMPTY_NS && !$fullscreen) {
10187229c84SAdrian Lang                // current namespace was removed. redirecting to root ns passing msg along
10287229c84SAdrian Lang                send_redirect(DOKU_URL.'lib/exe/mediamanager.php?msg1='.
103*8108113cSTom N Harris                        rawurlencode($msg).'&edid='.$INPUT->str('edid'));
10487229c84SAdrian Lang            }
10587229c84SAdrian Lang            msg($msg,1);
10687229c84SAdrian Lang        } elseif ($res & DOKU_MEDIA_INUSE) {
107666cdec5SMichael Klier            if(!$conf['refshow']) {
108d5b31577SChristian Marg                msg(sprintf($lang['mediainuse'],noNS($DEL)),0);
109666cdec5SMichael Klier            }
11087229c84SAdrian Lang        } else {
11187229c84SAdrian Lang            msg(sprintf($lang['deletefail'],noNS($DEL)),-1);
112666cdec5SMichael Klier        }
1133df72098SAndreas Gohr    }
1143df72098SAndreas Gohr    // finished - start output
115d9162c6cSKate Arzamastseva
11688a71175SKate Arzamastseva    if (!$fullscreen) {
1173df72098SAndreas Gohr        header('Content-Type: text/html; charset=utf-8');
1183df72098SAndreas Gohr        include(template('mediamanager.php'));
119d9162c6cSKate Arzamastseva    }
120365be586SAndreas Gohr
121365be586SAndreas Gohr/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
122