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 15*ca22711eSChristopher Smith global $DEL; 163df72098SAndreas Gohr // get namespace to display (either direct or from deletion order) 178108113cSTom N Harris if($INPUT->str('delete')){ 188108113cSTom N Harris $DEL = cleanID($INPUT->str('delete')); 19a05e297aSAndreas Gohr $IMG = $DEL; 203df72098SAndreas Gohr $NS = getNS($DEL); 218108113cSTom N Harris }elseif($INPUT->str('edit')){ 228108113cSTom N Harris $IMG = cleanID($INPUT->str('edit')); 233df72098SAndreas Gohr $NS = getNS($IMG); 248108113cSTom N Harris }elseif($INPUT->str('img')){ 258108113cSTom N Harris $IMG = cleanID($INPUT->str('img')); 263df72098SAndreas Gohr $NS = getNS($IMG); 273df72098SAndreas Gohr }else{ 288108113cSTom N Harris $NS = cleanID($INPUT->str('ns')); 291015a57dSChristopher Smith $IMG = null; 303df72098SAndreas Gohr } 313df72098SAndreas Gohr 32*ca22711eSChristopher Smith global $INFO; 33*ca22711eSChristopher Smith $INFO = !empty($INFO) ? array_merge($INFO, mediainfo()) : mediainfo(); 341015a57dSChristopher Smith $AUTH = $INFO['perm']; // shortcut for historical reasons 351015a57dSChristopher Smith 361015a57dSChristopher Smith trigger_event('MEDIAMANAGER_STARTED',$tmp=array()); 371015a57dSChristopher Smith session_write_close(); //close session 383df72098SAndreas Gohr 390b34c70fSGina Haeussge // do not display the manager if user does not have read access 4088a71175SKate Arzamastseva if($AUTH < AUTH_READ && !$fullscreen) { 419d2e1be6SAndreas Gohr http_status(403); 420b34c70fSGina Haeussge die($lang['accessdenied']); 430b34c70fSGina Haeussge } 440b34c70fSGina Haeussge 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){ 509d2e1be6SAndreas Gohr http_status(400); 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 788108113cSTom N Harris if($IMG && @array_key_exists('save', $INPUT->arr('do'))){ 798108113cSTom N Harris $JUMPTO = media_metasave($IMG,$AUTH,$INPUT->arr('meta')); 80d9162c6cSKate Arzamastseva } 81d9162c6cSKate Arzamastseva 828108113cSTom N Harris if($IMG && ($INPUT->str('mediado') == 'save' || @array_key_exists('save', $INPUT->arr('mediado')))) { 838108113cSTom N Harris $JUMPTO = media_metasave($IMG,$AUTH,$INPUT->arr('meta')); 843df72098SAndreas Gohr } 853df72098SAndreas Gohr 868108113cSTom N Harris if ($INPUT->int('rev') && $conf['mediarevisions']) $REV = $INPUT->int('rev'); 879c1bd4bcSKate Arzamastseva 888108113cSTom N Harris if($INPUT->str('mediado') == 'restore' && $conf['mediarevisions']){ 898108113cSTom 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='. 1038108113cSTom 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