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