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 14d186898bSAndreas Gohr if($_REQUEST['msg1']) msg(hsc($_REQUEST['msg1']),1); 15d00ec455SAndreas Gohr if($_REQUEST['err']) msg(hsc($_REQUEST['err']),-1); 16d186898bSAndreas Gohr 173df72098SAndreas Gohr 183df72098SAndreas Gohr // get namespace to display (either direct or from deletion order) 193df72098SAndreas Gohr if($_REQUEST['delete']){ 203df72098SAndreas Gohr $DEL = cleanID($_REQUEST['delete']); 21a05e297aSAndreas Gohr $IMG = $DEL; 223df72098SAndreas Gohr $NS = getNS($DEL); 233df72098SAndreas Gohr }elseif($_REQUEST['edit']){ 243df72098SAndreas Gohr $IMG = cleanID($_REQUEST['edit']); 253df72098SAndreas Gohr $NS = getNS($IMG); 263df72098SAndreas Gohr }elseif($_REQUEST['img']){ 273df72098SAndreas Gohr $IMG = cleanID($_REQUEST['img']); 283df72098SAndreas Gohr $NS = getNS($IMG); 293df72098SAndreas Gohr }else{ 303df72098SAndreas Gohr $NS = $_REQUEST['ns']; 313df72098SAndreas Gohr $NS = cleanID($NS); 323df72098SAndreas Gohr } 333df72098SAndreas Gohr 343df72098SAndreas Gohr // check auth 353df72098SAndreas Gohr $AUTH = auth_quickaclcheck("$NS:*"); 363df72098SAndreas Gohr 370b34c70fSGina Haeussge // do not display the manager if user does not have read access 380b34c70fSGina Haeussge if($AUTH < AUTH_READ) { 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 79*d9162c6cSKate Arzamastseva if($IMG && @array_key_exists('save', $_REQUEST['do'])){ 80*d9162c6cSKate Arzamastseva $JUMPTO = media_metasave($IMG,$AUTH,$_REQUEST['meta']); 81*d9162c6cSKate Arzamastseva } 82*d9162c6cSKate Arzamastseva 83*d9162c6cSKate Arzamastseva if($IMG && @array_key_exists('save', $_REQUEST['mediado'])){ 843df72098SAndreas Gohr $JUMPTO = media_metasave($IMG,$AUTH,$_REQUEST['meta']); 853df72098SAndreas Gohr } 863df72098SAndreas Gohr 873df72098SAndreas Gohr // handle deletion 883df72098SAndreas Gohr if($DEL) { 8987229c84SAdrian Lang $res = 0; 9087229c84SAdrian Lang if(checkSecurityToken()) { 9187229c84SAdrian Lang $res = media_delete($DEL,$AUTH); 92666cdec5SMichael Klier } 9387229c84SAdrian Lang if ($res & DOKU_MEDIA_DELETED) { 9487229c84SAdrian Lang $msg = sprintf($lang['deletesucc'], noNS($DEL)); 9587229c84SAdrian Lang if ($res & DOKU_MEDIA_EMPTY_NS) { 9687229c84SAdrian Lang // current namespace was removed. redirecting to root ns passing msg along 9787229c84SAdrian Lang send_redirect(DOKU_URL.'lib/exe/mediamanager.php?msg1='. 98dea1115bSAdrian Lang rawurlencode($msg).'&edid='.$_REQUEST['edid']); 9987229c84SAdrian Lang } 10087229c84SAdrian Lang msg($msg,1); 10187229c84SAdrian Lang } elseif ($res & DOKU_MEDIA_INUSE) { 102666cdec5SMichael Klier if(!$conf['refshow']) { 103d5b31577SChristian Marg msg(sprintf($lang['mediainuse'],noNS($DEL)),0); 104666cdec5SMichael Klier } 10587229c84SAdrian Lang } else { 10687229c84SAdrian Lang msg(sprintf($lang['deletefail'],noNS($DEL)),-1); 107666cdec5SMichael Klier } 1083df72098SAndreas Gohr } 1093df72098SAndreas Gohr // finished - start output 110*d9162c6cSKate Arzamastseva 111*d9162c6cSKate Arzamastseva if (!($_REQUEST['do'] == 'media')) { 1123df72098SAndreas Gohr header('Content-Type: text/html; charset=utf-8'); 1133df72098SAndreas Gohr include(template('mediamanager.php')); 114*d9162c6cSKate Arzamastseva } 115365be586SAndreas Gohr 116365be586SAndreas Gohr/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */ 117