13df72098SAndreas Gohr<?php 23df72098SAndreas Gohr/** 33df72098SAndreas Gohr * All output and handler function needed for the media management popup 43df72098SAndreas Gohr * 53df72098SAndreas Gohr * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 63df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 73df72098SAndreas Gohr */ 83df72098SAndreas Gohr 93df72098SAndreas Gohrif(!defined('DOKU_INC')) define('DOKU_INC',realpath(dirname(__FILE__).'/../').'/'); 103df72098SAndreas Gohrif(!defined('NL')) define('NL',"\n"); 113df72098SAndreas Gohr 123df72098SAndreas Gohrrequire_once(DOKU_INC.'inc/html.php'); 133df72098SAndreas Gohrrequire_once(DOKU_INC.'inc/search.php'); 143df72098SAndreas Gohrrequire_once(DOKU_INC.'inc/JpegMeta.php'); 153df72098SAndreas Gohr 163df72098SAndreas Gohr/** 173df72098SAndreas Gohr * Lists pages which currently use a media file selected for deletion 183df72098SAndreas Gohr * 193df72098SAndreas Gohr * References uses the same visual as search results and share 203df72098SAndreas Gohr * their CSS tags except pagenames won't be links. 213df72098SAndreas Gohr * 223df72098SAndreas Gohr * @author Matthias Grimm <matthiasgrimm@users.sourceforge.net> 233df72098SAndreas Gohr */ 243df72098SAndreas Gohrfunction media_filesinuse($data,$id){ 253df72098SAndreas Gohr global $lang; 263df72098SAndreas Gohr echo '<h1>'.$lang['reference'].' <code>'.hsc(noNS($id)).'</code></h1>'; 273df72098SAndreas Gohr echo '<p>'.hsc($lang['ref_inuse']).'</p>'; 283df72098SAndreas Gohr 293df72098SAndreas Gohr $hidden=0; //count of hits without read permission 303df72098SAndreas Gohr usort($data,'sort_search_fulltext'); 313df72098SAndreas Gohr foreach($data as $row){ 323df72098SAndreas Gohr if(auth_quickaclcheck($row['id']) >= AUTH_READ){ 333df72098SAndreas Gohr echo '<div class="search_result">'; 343df72098SAndreas Gohr echo '<span class="mediaref_ref">'.$row['id'].'</span>'; 353df72098SAndreas Gohr echo ': <span class="search_cnt">'.$row['count'].' '.$lang['hits'].'</span><br />'; 363df72098SAndreas Gohr echo '<div class="search_snippet">'.$row['snippet'].'</div>'; 373df72098SAndreas Gohr echo '</div>'; 383df72098SAndreas Gohr }else 393df72098SAndreas Gohr $hidden++; 403df72098SAndreas Gohr } 413df72098SAndreas Gohr if ($hidden){ 423df72098SAndreas Gohr print '<div class="mediaref_hidden">'.$lang['ref_hidden'].'</div>'; 433df72098SAndreas Gohr } 443df72098SAndreas Gohr} 453df72098SAndreas Gohr 463df72098SAndreas Gohr/** 473df72098SAndreas Gohr * Handles the saving of image meta data 483df72098SAndreas Gohr * 493df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 503df72098SAndreas Gohr */ 513df72098SAndreas Gohrfunction media_metasave($id,$auth,$data){ 523df72098SAndreas Gohr if($auth < AUTH_UPLOAD) return false; 53f2ea8432SAndreas Gohr if(!checkSecurityToken()) return false; 543df72098SAndreas Gohr global $lang; 553df72098SAndreas Gohr $src = mediaFN($id); 563df72098SAndreas Gohr 573df72098SAndreas Gohr $meta = new JpegMeta($src); 583df72098SAndreas Gohr $meta->_parseAll(); 593df72098SAndreas Gohr 603df72098SAndreas Gohr foreach($data as $key => $val){ 613df72098SAndreas Gohr $val=trim($val); 623df72098SAndreas Gohr if(empty($val)){ 633df72098SAndreas Gohr $meta->deleteField($key); 643df72098SAndreas Gohr }else{ 653df72098SAndreas Gohr $meta->setField($key,$val); 663df72098SAndreas Gohr } 673df72098SAndreas Gohr } 683df72098SAndreas Gohr 693df72098SAndreas Gohr if($meta->save()){ 703df72098SAndreas Gohr msg($lang['metasaveok'],1); 713df72098SAndreas Gohr return $id; 723df72098SAndreas Gohr }else{ 733df72098SAndreas Gohr msg($lang['metasaveerr'],-1); 743df72098SAndreas Gohr return false; 753df72098SAndreas Gohr } 763df72098SAndreas Gohr} 773df72098SAndreas Gohr 783df72098SAndreas Gohr/** 793df72098SAndreas Gohr * Display the form to edit image meta data 803df72098SAndreas Gohr * 813df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 823df72098SAndreas Gohr */ 833df72098SAndreas Gohrfunction media_metaform($id,$auth){ 843df72098SAndreas Gohr if($auth < AUTH_UPLOAD) return false; 853df72098SAndreas Gohr global $lang; 863df72098SAndreas Gohr 873df72098SAndreas Gohr // load the field descriptions 883df72098SAndreas Gohr static $fields = null; 893df72098SAndreas Gohr if(is_null($fields)){ 903df72098SAndreas Gohr include(DOKU_CONF.'mediameta.php'); 913df72098SAndreas Gohr if(@file_exists(DOKU_CONF.'mediameta.local.php')){ 923df72098SAndreas Gohr include(DOKU_CONF.'mediameta.local.php'); 933df72098SAndreas Gohr } 943df72098SAndreas Gohr } 953df72098SAndreas Gohr 963df72098SAndreas Gohr $src = mediaFN($id); 973df72098SAndreas Gohr 983df72098SAndreas Gohr // output 993df72098SAndreas Gohr echo '<h1>'.hsc(noNS($id)).'</h1>'.NL; 1003df72098SAndreas Gohr echo '<form action="'.DOKU_BASE.'lib/exe/mediamanager.php" accept-charset="utf-8" method="post" class="meta">'.NL; 101f2ea8432SAndreas Gohr formSecurityToken(); 1023df72098SAndreas Gohr foreach($fields as $key => $field){ 1033df72098SAndreas Gohr // get current value 1043df72098SAndreas Gohr $tags = array($field[0]); 1053df72098SAndreas Gohr if(is_array($field[3])) $tags = array_merge($tags,$field[3]); 1063df72098SAndreas Gohr $value = tpl_img_getTag($tags,'',$src); 1073df72098SAndreas Gohr 1083df72098SAndreas Gohr // prepare attributes 1093df72098SAndreas Gohr $p = array(); 1103df72098SAndreas Gohr $p['class'] = 'edit'; 1113df72098SAndreas Gohr $p['id'] = 'meta__'.$key; 1123df72098SAndreas Gohr $p['name'] = 'meta['.$field[0].']'; 1133df72098SAndreas Gohr 1143df72098SAndreas Gohr // put label 1153df72098SAndreas Gohr echo '<div class="metafield">'; 1163df72098SAndreas Gohr echo '<label for="meta__'.$key.'">'; 1173df72098SAndreas Gohr echo ($lang[$field[1]]) ? $lang[$field[1]] : $field[1]; 118cf6894dfSAndreas Gohr echo ':</label>'; 1193df72098SAndreas Gohr 1203df72098SAndreas Gohr // put input field 1213df72098SAndreas Gohr if($field[2] == 'text'){ 1223df72098SAndreas Gohr $p['value'] = $value; 1233df72098SAndreas Gohr $p['type'] = 'text'; 1243df72098SAndreas Gohr $att = buildAttributes($p); 1253df72098SAndreas Gohr echo "<input $att/>".NL; 1263df72098SAndreas Gohr }else{ 1273df72098SAndreas Gohr $att = buildAttributes($p); 1281440e523SAnika Henke echo "<textarea $att rows=\"6\" cols=\"50\">".formText($value).'</textarea>'.NL; 1293df72098SAndreas Gohr } 1303df72098SAndreas Gohr echo '</div>'.NL; 1313df72098SAndreas Gohr } 1323df72098SAndreas Gohr echo '<div class="buttons">'.NL; 1331440e523SAnika Henke echo '<input type="hidden" name="img" value="'.hsc($id).'" />'.NL; 1343df72098SAndreas Gohr echo '<input name="do[save]" type="submit" value="'.$lang['btn_save']. 1353df72098SAndreas Gohr '" title="ALT+S" accesskey="s" class="button" />'.NL; 1363df72098SAndreas Gohr echo '<input name="do[cancel]" type="submit" value="'.$lang['btn_cancel']. 1373df72098SAndreas Gohr '" title="ALT+C" accesskey="c" class="button" />'.NL; 1384868e1c6SAndreas Gohr echo '</div>'.NL; 1393df72098SAndreas Gohr echo '</form>'.NL; 1403df72098SAndreas Gohr} 1413df72098SAndreas Gohr 1423df72098SAndreas Gohr/** 1433df72098SAndreas Gohr * Handles media file deletions 1443df72098SAndreas Gohr * 1453df72098SAndreas Gohr * If configured, checks for media references before deletion 1463df72098SAndreas Gohr * 1473df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 1483df72098SAndreas Gohr * @return mixed false on error, true on delete or array with refs 1493df72098SAndreas Gohr */ 1503df72098SAndreas Gohrfunction media_delete($id,$auth){ 1513df72098SAndreas Gohr if($auth < AUTH_DELETE) return false; 152f2ea8432SAndreas Gohr if(!checkSecurityToken()) return false; 1533df72098SAndreas Gohr global $conf; 1543df72098SAndreas Gohr global $lang; 1553df72098SAndreas Gohr 1563df72098SAndreas Gohr $mediareferences = array(); 1573df72098SAndreas Gohr if($conf['refcheck']){ 1583df72098SAndreas Gohr search($mediareferences,$conf['datadir'],'search_reference',array('query' => $id)); 1593df72098SAndreas Gohr } 1603df72098SAndreas Gohr 1613df72098SAndreas Gohr if(!count($mediareferences)){ 1623df72098SAndreas Gohr $file = mediaFN($id); 1633df72098SAndreas Gohr if(@unlink($file)){ 1643df72098SAndreas Gohr msg(str_replace('%s',noNS($id),$lang['deletesucc']),1); 1653df72098SAndreas Gohr io_sweepNS($id,'mediadir'); 1663df72098SAndreas Gohr return true; 1673df72098SAndreas Gohr } 1683df72098SAndreas Gohr //something went wrong 1693df72098SAndreas Gohr msg(str_replace('%s',$file,$lang['deletefail']),-1); 1703df72098SAndreas Gohr return false; 1713df72098SAndreas Gohr }elseif(!$conf['refshow']){ 1723df72098SAndreas Gohr msg(str_replace('%s',noNS($id),$lang['mediainuse']),0); 1733df72098SAndreas Gohr return false; 1743df72098SAndreas Gohr } 1753df72098SAndreas Gohr 1763df72098SAndreas Gohr return $mediareferences; 1773df72098SAndreas Gohr} 1783df72098SAndreas Gohr 1793df72098SAndreas Gohr/** 1803df72098SAndreas Gohr * Handles media file uploads 1813df72098SAndreas Gohr * 1823df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 1833df72098SAndreas Gohr * @return mixed false on error, id of the new file on success 1843df72098SAndreas Gohr */ 1853df72098SAndreas Gohrfunction media_upload($ns,$auth){ 1863df72098SAndreas Gohr if($auth < AUTH_UPLOAD) return false; 187f2ea8432SAndreas Gohr if(!checkSecurityToken()) return false; 1883df72098SAndreas Gohr require_once(DOKU_INC.'inc/confutils.php'); 1893df72098SAndreas Gohr global $lang; 1903df72098SAndreas Gohr global $conf; 1913df72098SAndreas Gohr 19244409c3dSAndreas Gohr // get file and id 1933df72098SAndreas Gohr $id = $_POST['id']; 1943df72098SAndreas Gohr $file = $_FILES['upload']; 1953df72098SAndreas Gohr if(empty($id)) $id = $file['name']; 19644409c3dSAndreas Gohr 19744409c3dSAndreas Gohr // check extensions 1988cb1eb01SAndreas Gohr list($fext,$fmime) = mimetype($file['name']); 1998cb1eb01SAndreas Gohr list($iext,$imime) = mimetype($id); 20044409c3dSAndreas Gohr if($fext && !$iext){ 2018cb1eb01SAndreas Gohr // no extension specified in id - read original one 20244409c3dSAndreas Gohr $id .= '.'.$fext; 2038cb1eb01SAndreas Gohr $imime = $fmime; 20444409c3dSAndreas Gohr }elseif($fext && $fext != $iext){ 20544409c3dSAndreas Gohr // extension was changed, print warning 20644409c3dSAndreas Gohr msg(sprintf($lang['mediaextchange'],$fext,$iext)); 20744409c3dSAndreas Gohr } 20844409c3dSAndreas Gohr 2093df72098SAndreas Gohr // get filename 21044409c3dSAndreas Gohr $id = cleanID($ns.':'.$id); 2113df72098SAndreas Gohr $fn = mediaFN($id); 2123df72098SAndreas Gohr 2133df72098SAndreas Gohr // get filetype regexp 2143df72098SAndreas Gohr $types = array_keys(getMimeTypes()); 2153df72098SAndreas Gohr $types = array_map(create_function('$q','return preg_quote($q,"/");'),$types); 2163df72098SAndreas Gohr $regex = join('|',$types); 2173df72098SAndreas Gohr 2183df72098SAndreas Gohr // because a temp file was created already 2193df72098SAndreas Gohr if(preg_match('/\.('.$regex.')$/i',$fn)){ 2203df72098SAndreas Gohr //check for overwrite 2213df72098SAndreas Gohr if(@file_exists($fn) && (!$_POST['ow'] || $auth < AUTH_DELETE)){ 2223df72098SAndreas Gohr msg($lang['uploadexist'],0); 2233df72098SAndreas Gohr return false; 2243df72098SAndreas Gohr } 2258cb1eb01SAndreas Gohr // check for valid content 2268cb1eb01SAndreas Gohr $ok = media_contentcheck($file['tmp_name'],$imime); 2278cb1eb01SAndreas Gohr if($ok == -1){ 2288cb1eb01SAndreas Gohr msg(sprintf($lang['uploadbadcontent'],".$iext"),-1); 2298cb1eb01SAndreas Gohr return false; 2308cb1eb01SAndreas Gohr }elseif($ok == -2){ 2318cb1eb01SAndreas Gohr msg($lang['uploadspam'],-1); 2328cb1eb01SAndreas Gohr return false; 23326ceae18SAndreas Gohr }elseif($ok == -3){ 23426ceae18SAndreas Gohr msg($lang['uploadxss'],-1); 23526ceae18SAndreas Gohr return false; 2368cb1eb01SAndreas Gohr } 2378cb1eb01SAndreas Gohr 2383df72098SAndreas Gohr // prepare directory 239cc7d0c94SBen Coburn io_createNamespace($id, 'media'); 2403df72098SAndreas Gohr if(move_uploaded_file($file['tmp_name'], $fn)) { 24174400ea5SBen Coburn // Set the correct permission here. 24274400ea5SBen Coburn // Always chmod media because they may be saved with different permissions than expected from the php umask. 24374400ea5SBen Coburn // (Should normally chmod to $conf['fperm'] only if $conf['fperm'] is set.) 24474400ea5SBen Coburn chmod($fn, $conf['fmode']); 2453df72098SAndreas Gohr msg($lang['uploadsucc'],1); 24675030359SAndreas Gohr media_notify($id,$fn,$imime); 2473df72098SAndreas Gohr return $id; 2483df72098SAndreas Gohr }else{ 2493df72098SAndreas Gohr msg($lang['uploadfail'],-1); 2503df72098SAndreas Gohr } 2513df72098SAndreas Gohr }else{ 2523df72098SAndreas Gohr msg($lang['uploadwrong'],-1); 2533df72098SAndreas Gohr } 2543df72098SAndreas Gohr return false; 2553df72098SAndreas Gohr} 2563df72098SAndreas Gohr 2578cb1eb01SAndreas Gohr/** 2588cb1eb01SAndreas Gohr * This function checks if the uploaded content is really what the 25926ceae18SAndreas Gohr * mimetype says it is. We also do spam checking for text types here. 2608cb1eb01SAndreas Gohr * 2618cb1eb01SAndreas Gohr * We need to do this stuff because we can not rely on the browser 2628cb1eb01SAndreas Gohr * to do this check correctly. Yes, IE is broken as usual. 2638cb1eb01SAndreas Gohr * 2648cb1eb01SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 26526ceae18SAndreas Gohr * @link http://www.splitbrain.org/blog/2007-02/12-internet_explorer_facilitates_cross_site_scripting 2668cb1eb01SAndreas Gohr * @fixme check all 26 magic IE filetypes here? 2678cb1eb01SAndreas Gohr */ 2688cb1eb01SAndreas Gohrfunction media_contentcheck($file,$mime){ 26926ceae18SAndreas Gohr global $conf; 27026ceae18SAndreas Gohr if($conf['iexssprotect']){ 27126ceae18SAndreas Gohr $fh = @fopen($file, 'rb'); 27226ceae18SAndreas Gohr if($fh){ 27326ceae18SAndreas Gohr $bytes = fread($fh, 256); 27426ceae18SAndreas Gohr fclose($fh); 27526ceae18SAndreas Gohr if(preg_match('/<(script|a|img|html|body|iframe)[\s>]/i',$bytes)){ 27626ceae18SAndreas Gohr return -3; 27726ceae18SAndreas Gohr } 27826ceae18SAndreas Gohr } 27926ceae18SAndreas Gohr } 2808cb1eb01SAndreas Gohr if(substr($mime,0,6) == 'image/'){ 2818cb1eb01SAndreas Gohr $info = @getimagesize($file); 2828cb1eb01SAndreas Gohr if($mime == 'image/gif' && $info[2] != 1){ 2838cb1eb01SAndreas Gohr return -1; 2848cb1eb01SAndreas Gohr }elseif($mime == 'image/jpeg' && $info[2] != 2){ 2858cb1eb01SAndreas Gohr return -1; 2868cb1eb01SAndreas Gohr }elseif($mime == 'image/png' && $info[2] != 3){ 2878cb1eb01SAndreas Gohr return -1; 2888cb1eb01SAndreas Gohr } 2898cb1eb01SAndreas Gohr # fixme maybe check other images types as well 2908cb1eb01SAndreas Gohr }elseif(substr($mime,0,5) == 'text/'){ 2918cb1eb01SAndreas Gohr global $TEXT; 2928cb1eb01SAndreas Gohr $TEXT = io_readFile($file); 2938cb1eb01SAndreas Gohr if(checkwordblock()){ 2948cb1eb01SAndreas Gohr return -2; 2958cb1eb01SAndreas Gohr } 2968cb1eb01SAndreas Gohr } 2978cb1eb01SAndreas Gohr return 0; 2988cb1eb01SAndreas Gohr} 2993df72098SAndreas Gohr 3003df72098SAndreas Gohr/** 30175030359SAndreas Gohr * Send a notify mail on uploads 30275030359SAndreas Gohr * 30375030359SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 30475030359SAndreas Gohr */ 30575030359SAndreas Gohrfunction media_notify($id,$file,$mime){ 30675030359SAndreas Gohr global $lang; 30775030359SAndreas Gohr global $conf; 30875030359SAndreas Gohr if(empty($conf['notify'])) return; //notify enabled? 30975030359SAndreas Gohr 31075030359SAndreas Gohr $text = rawLocale('uploadmail'); 31175030359SAndreas Gohr $text = str_replace('@DATE@',date($conf['dformat']),$text); 31275030359SAndreas Gohr $text = str_replace('@BROWSER@',$_SERVER['HTTP_USER_AGENT'],$text); 31375030359SAndreas Gohr $text = str_replace('@IPADDRESS@',$_SERVER['REMOTE_ADDR'],$text); 31475030359SAndreas Gohr $text = str_replace('@HOSTNAME@',gethostbyaddr($_SERVER['REMOTE_ADDR']),$text); 31575030359SAndreas Gohr $text = str_replace('@DOKUWIKIURL@',DOKU_URL,$text); 31675030359SAndreas Gohr $text = str_replace('@USER@',$_SERVER['REMOTE_USER'],$text); 31775030359SAndreas Gohr $text = str_replace('@MIME@',$mime,$text); 31855b2b31bSAndreas Gohr $text = str_replace('@MEDIA@',ml($id,'',true,'&',true),$text); 31975030359SAndreas Gohr $text = str_replace('@SIZE@',filesize_h(filesize($file)),$text); 32075030359SAndreas Gohr 32175030359SAndreas Gohr $from = $conf['mailfrom']; 32275030359SAndreas Gohr $from = str_replace('@USER@',$_SERVER['REMOTE_USER'],$from); 32375030359SAndreas Gohr $from = str_replace('@NAME@',$INFO['userinfo']['name'],$from); 32475030359SAndreas Gohr $from = str_replace('@MAIL@',$INFO['userinfo']['mail'],$from); 32575030359SAndreas Gohr 32675030359SAndreas Gohr $subject = '['.$conf['title'].'] '.$lang['mail_upload'].' '.$id; 32775030359SAndreas Gohr 32875030359SAndreas Gohr mail_send($conf['notify'],$subject,$text,$from); 32975030359SAndreas Gohr} 33075030359SAndreas Gohr 33175030359SAndreas Gohr/** 3323df72098SAndreas Gohr * List all files in a given Media namespace 3333df72098SAndreas Gohr */ 3343df72098SAndreas Gohrfunction media_filelist($ns,$auth=null,$jump=''){ 3353df72098SAndreas Gohr global $conf; 3363df72098SAndreas Gohr global $lang; 3373df72098SAndreas Gohr $ns = cleanID($ns); 3383df72098SAndreas Gohr 3393df72098SAndreas Gohr // check auth our self if not given (needed for ajax calls) 3403df72098SAndreas Gohr if(is_null($auth)) $auth = auth_quickaclcheck("$ns:*"); 3413df72098SAndreas Gohr 3426c48a22eSAndreas Gohr echo '<h1 id="media__ns">:'.hsc($ns).'</h1>'.NL; 3433df72098SAndreas Gohr 3443df72098SAndreas Gohr if($auth < AUTH_READ){ 3453df72098SAndreas Gohr // FIXME: print permission warning here instead? 3463df72098SAndreas Gohr echo '<div class="nothing">'.$lang['nothingfound'].'</div>'.NL; 3473df72098SAndreas Gohr return; 3483df72098SAndreas Gohr } 3493df72098SAndreas Gohr 3503df72098SAndreas Gohr media_uploadform($ns, $auth); 3513df72098SAndreas Gohr 3523df72098SAndreas Gohr $dir = utf8_encodeFN(str_replace(':','/',$ns)); 3533df72098SAndreas Gohr $data = array(); 3543df72098SAndreas Gohr search($data,$conf['mediadir'],'search_media',array(),$dir); 3553df72098SAndreas Gohr 3563df72098SAndreas Gohr if(!count($data)){ 3573df72098SAndreas Gohr echo '<div class="nothing">'.$lang['nothingfound'].'</div>'.NL; 3583df72098SAndreas Gohr return; 3593df72098SAndreas Gohr } 3603df72098SAndreas Gohr 3613df72098SAndreas Gohr foreach($data as $item){ 3623df72098SAndreas Gohr media_printfile($item,$auth,$jump); 3633df72098SAndreas Gohr } 3643df72098SAndreas Gohr} 3653df72098SAndreas Gohr 3663df72098SAndreas Gohr/** 3673df72098SAndreas Gohr * Print action links for a file depending on filetype 3683df72098SAndreas Gohr * and available permissions 3693df72098SAndreas Gohr * 3703df72098SAndreas Gohr * @todo contains inline javascript 3713df72098SAndreas Gohr */ 3723df72098SAndreas Gohrfunction media_fileactions($item,$auth){ 3733df72098SAndreas Gohr global $lang; 3743df72098SAndreas Gohr 375cf6894dfSAndreas Gohr // view button 376cf6894dfSAndreas Gohr $link = ml($item['id'],'',true); 377cf6894dfSAndreas Gohr echo ' <a href="'.$link.'" target="_blank"><img src="'.DOKU_BASE.'lib/images/magnifier.png" '. 378cf6894dfSAndreas Gohr 'alt="'.$lang['mediaview'].'" title="'.$lang['mediaview'].'" class="btn" /></a>'; 379cf6894dfSAndreas Gohr 380cf6894dfSAndreas Gohr 381cf6894dfSAndreas Gohr // no further actions if not writable 3823df72098SAndreas Gohr if(!$item['writable']) return; 3833df72098SAndreas Gohr 3843df72098SAndreas Gohr // delete button 3853df72098SAndreas Gohr if($auth >= AUTH_DELETE){ 3863df72098SAndreas Gohr $ask = addslashes($lang['del_confirm']).'\\n'; 3873df72098SAndreas Gohr $ask .= addslashes($item['id']); 3883df72098SAndreas Gohr 389f2ea8432SAndreas Gohr echo ' <a href="'.DOKU_BASE.'lib/exe/mediamanager.php?delete='.rawurlencode($item['id']). 390*e681fae7SMichael Klier '&sectok='.getSecurityToken().'" '. 3913df72098SAndreas Gohr 'onclick="return confirm(\''.$ask.'\')" onkeypress="return confirm(\''.$ask.'\')">'. 3923df72098SAndreas Gohr '<img src="'.DOKU_BASE.'lib/images/trash.png" alt="'.$lang['btn_delete'].'" '. 3933df72098SAndreas Gohr 'title="'.$lang['btn_delete'].'" class="btn" /></a>'; 3943df72098SAndreas Gohr } 3953df72098SAndreas Gohr 3963df72098SAndreas Gohr // edit button 3973df72098SAndreas Gohr if($auth >= AUTH_UPLOAD && $item['isimg'] && $item['meta']->getField('File.Mime') == 'image/jpeg'){ 3983df72098SAndreas Gohr echo ' <a href="'.DOKU_BASE.'lib/exe/mediamanager.php?edit='.rawurlencode($item['id']).'">'. 3993df72098SAndreas Gohr '<img src="'.DOKU_BASE.'lib/images/pencil.png" alt="'.$lang['metaedit'].'" '. 4003df72098SAndreas Gohr 'title="'.$lang['metaedit'].'" class="btn" /></a>'; 4013df72098SAndreas Gohr } 4023df72098SAndreas Gohr 4033df72098SAndreas Gohr} 4043df72098SAndreas Gohr 4053df72098SAndreas Gohr/** 4063df72098SAndreas Gohr * Formats and prints one file in the list 4073df72098SAndreas Gohr */ 4083df72098SAndreas Gohrfunction media_printfile($item,$auth,$jump){ 40964c9cfd5SAndreas Gohr global $lang; 4105e7fa82eSAndreas Gohr global $conf; 41164c9cfd5SAndreas Gohr 4123df72098SAndreas Gohr // Prepare zebra coloring 4133df72098SAndreas Gohr // I always wanted to use this variable name :-D 4143df72098SAndreas Gohr static $twibble = 1; 4153df72098SAndreas Gohr $twibble *= -1; 4163df72098SAndreas Gohr $zebra = ($twibble == -1) ? 'odd' : 'even'; 4173df72098SAndreas Gohr 4183df72098SAndreas Gohr // Automatically jump to recent action 4193df72098SAndreas Gohr if($jump == $item['id']) { 4203df72098SAndreas Gohr $jump = ' id="scroll__here" '; 4213df72098SAndreas Gohr }else{ 4223df72098SAndreas Gohr $jump = ''; 4233df72098SAndreas Gohr } 4243df72098SAndreas Gohr 4253df72098SAndreas Gohr // Prepare fileicons 4263df72098SAndreas Gohr list($ext,$mime) = mimetype($item['file']); 4273df72098SAndreas Gohr $class = preg_replace('/[^_\-a-z0-9]+/i','_',$ext); 4283df72098SAndreas Gohr $class = 'select mediafile mf_'.$class; 4293df72098SAndreas Gohr 4303df72098SAndreas Gohr // Prepare filename 4313df72098SAndreas Gohr $file = utf8_decodeFN($item['file']); 4323df72098SAndreas Gohr 4333df72098SAndreas Gohr // Prepare info 4343df72098SAndreas Gohr $info = ''; 4353df72098SAndreas Gohr if($item['isimg']){ 4363df72098SAndreas Gohr $info .= (int) $item['meta']->getField('File.Width'); 4373df72098SAndreas Gohr $info .= '×'; 4383df72098SAndreas Gohr $info .= (int) $item['meta']->getField('File.Height'); 4393df72098SAndreas Gohr $info .= ' '; 4403df72098SAndreas Gohr } 4415e7fa82eSAndreas Gohr $info .= '<i>'.date($conf['dformat'],$item['mtime']).'</i>'; 4425e7fa82eSAndreas Gohr $info .= ' '; 4433df72098SAndreas Gohr $info .= filesize_h($item['size']); 4443df72098SAndreas Gohr 4453df72098SAndreas Gohr // ouput 4463df72098SAndreas Gohr echo '<div class="'.$zebra.'"'.$jump.'>'.NL; 4473df72098SAndreas Gohr echo '<a name="h_'.$item['id'].'" class="'.$class.'">'.$file.'</a> '; 4483df72098SAndreas Gohr echo '<span class="info">('.$info.')</span>'.NL; 4493df72098SAndreas Gohr media_fileactions($item,$auth); 450f495da32SAnika Henke echo '<div class="example" id="ex_'.str_replace(':','_',$item['id']).'">'; 4510b173dceSAndreas Gohr echo $lang['mediausage'].' <code>{{:'.$item['id'].'}}</code>'; 45264c9cfd5SAndreas Gohr echo '</div>'; 4533df72098SAndreas Gohr if($item['isimg']) media_printimgdetail($item); 4543df72098SAndreas Gohr echo '<div class="clearer"></div>'.NL; 4553df72098SAndreas Gohr echo '</div>'.NL; 4563df72098SAndreas Gohr} 4573df72098SAndreas Gohr 4583df72098SAndreas Gohr/** 4593df72098SAndreas Gohr * Prints a thumbnail and metainfos 4603df72098SAndreas Gohr */ 4613df72098SAndreas Gohrfunction media_printimgdetail($item){ 4623df72098SAndreas Gohr // prepare thumbnail 4633df72098SAndreas Gohr $w = (int) $item['meta']->getField('File.Width'); 4643df72098SAndreas Gohr $h = (int) $item['meta']->getField('File.Height'); 4653df72098SAndreas Gohr if($w>120 || $h>120){ 4663df72098SAndreas Gohr $ratio = $item['meta']->getResizeRatio(120); 4673df72098SAndreas Gohr $w = floor($w * $ratio); 4683df72098SAndreas Gohr $h = floor($h * $ratio); 4693df72098SAndreas Gohr } 4703df72098SAndreas Gohr $src = ml($item['id'],array('w'=>$w,'h'=>$h)); 4713df72098SAndreas Gohr $p = array(); 4723df72098SAndreas Gohr $p['width'] = $w; 4733df72098SAndreas Gohr $p['height'] = $h; 4743df72098SAndreas Gohr $p['alt'] = $item['id']; 4753df72098SAndreas Gohr $p['class'] = 'thumb'; 4763df72098SAndreas Gohr $att = buildAttributes($p); 4773df72098SAndreas Gohr 4783df72098SAndreas Gohr // output 4793df72098SAndreas Gohr echo '<div class="detail">'; 4803df72098SAndreas Gohr echo '<div class="thumb">'; 4813df72098SAndreas Gohr echo '<a name="d_'.$item['id'].'" class="select">'; 4823df72098SAndreas Gohr echo '<img src="'.$src.'" '.$att.' />'; 4833df72098SAndreas Gohr echo '</a>'; 4843df72098SAndreas Gohr echo '</div>'; 4853df72098SAndreas Gohr 4863df72098SAndreas Gohr // read EXIF/IPTC data 4873df72098SAndreas Gohr $t = $item['meta']->getField('IPTC.Headline'); 4880b173dceSAndreas Gohr $d = $item['meta']->getField(array('IPTC.Caption','EXIF.UserComment', 4893df72098SAndreas Gohr 'EXIF.TIFFImageDescription', 4903df72098SAndreas Gohr 'EXIF.TIFFUserComment')); 4910b173dceSAndreas Gohr if(utf8_strlen($d) > 250) $d = utf8_substr($d,0,250).'...'; 4920b173dceSAndreas Gohr $k = $item['meta']->getField(array('IPTC.Keywords','IPTC.Category')); 4933df72098SAndreas Gohr 4940b173dceSAndreas Gohr // print EXIF/IPTC data 4950b173dceSAndreas Gohr if($t || $d || $k ){ 4960b173dceSAndreas Gohr echo '<p>'; 4970b173dceSAndreas Gohr if($t) echo '<strong>'.htmlspecialchars($t).'</strong><br />'; 4980b173dceSAndreas Gohr if($d) echo htmlspecialchars($d).'<br />'; 4990b173dceSAndreas Gohr if($t) echo '<em>'.htmlspecialchars($k).'</em>'; 5003df72098SAndreas Gohr echo '</p>'; 5010b173dceSAndreas Gohr } 5023df72098SAndreas Gohr echo '</div>'; 5033df72098SAndreas Gohr} 5043df72098SAndreas Gohr 5053df72098SAndreas Gohr/** 5063df72098SAndreas Gohr * Print the media upload form if permissions are correct 5073df72098SAndreas Gohr * 5083df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 5093df72098SAndreas Gohr */ 5103df72098SAndreas Gohrfunction media_uploadform($ns, $auth){ 5113df72098SAndreas Gohr global $lang; 5123df72098SAndreas Gohr 5133df72098SAndreas Gohr if($auth < AUTH_UPLOAD) return; //fixme print info on missing permissions? 5143df72098SAndreas Gohr 5153df72098SAndreas Gohr ?> 516cf6894dfSAndreas Gohr <div class="upload"><?php echo $lang['mediaupload']?></div> 5173df72098SAndreas Gohr <form action="<?php echo DOKU_BASE?>lib/exe/mediamanager.php" 5183df72098SAndreas Gohr method="post" enctype="multipart/form-data" class="upload"> 5198902ae3dSAnika Henke <fieldset> 520f495da32SAnika Henke <legend class="hidden"><?php echo $lang['btn_upload']?></legend> 5213df72098SAndreas Gohr <input type="hidden" name="ns" value="<?php echo hsc($ns)?>" /> 522f2ea8432SAndreas Gohr <?php formSecurityToken();?> 5238902ae3dSAnika Henke <p> 5248902ae3dSAnika Henke <label for="upload__file"><?php echo $lang['txt_upload']?>:</label> 5258902ae3dSAnika Henke <input type="file" name="upload" class="edit" id="upload__file" /> 5268902ae3dSAnika Henke </p> 527cf6894dfSAndreas Gohr 5288902ae3dSAnika Henke <p> 5298902ae3dSAnika Henke <label for="upload__name"><?php echo $lang['txt_filename']?>:</label> 53018d69493SAndreas Gohr <span class="nowrap"> 53144e099adSAndreas Gohr <input type="text" name="id" class="edit" id="upload__name" /><input 53244e099adSAndreas Gohr type="submit" class="button" value="<?php echo $lang['btn_upload']?>" 53344e099adSAndreas Gohr accesskey="s" /> 53444e099adSAndreas Gohr </span> 5358902ae3dSAnika Henke </p> 5363df72098SAndreas Gohr 5373df72098SAndreas Gohr <?php if($auth >= AUTH_DELETE){?> 5388902ae3dSAnika Henke <p> 5398902ae3dSAnika Henke <input type="checkbox" name="ow" value="1" id="dw__ow" class="check" /> 5408902ae3dSAnika Henke <label for="dw__ow" class="check"><?php echo $lang['txt_overwrt']?></label> 5418902ae3dSAnika Henke </p> 5423df72098SAndreas Gohr <?php }?> 5438902ae3dSAnika Henke </fieldset> 5443df72098SAndreas Gohr </form> 5453df72098SAndreas Gohr <?php 5463df72098SAndreas Gohr} 5473df72098SAndreas Gohr 5483df72098SAndreas Gohr 5493df72098SAndreas Gohr 5503df72098SAndreas Gohr/** 5513df72098SAndreas Gohr * Build a tree outline of available media namespaces 5523df72098SAndreas Gohr * 5533df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 5543df72098SAndreas Gohr */ 5553df72098SAndreas Gohrfunction media_nstree($ns){ 5563df72098SAndreas Gohr global $conf; 557256ca81eSAndreas Gohr global $lang; 5583df72098SAndreas Gohr 5593df72098SAndreas Gohr // currently selected namespace 5603df72098SAndreas Gohr $ns = cleanID($ns); 5613df72098SAndreas Gohr if(empty($ns)){ 5623df72098SAndreas Gohr $ns = dirname(str_replace(':','/',$ID)); 5633df72098SAndreas Gohr if($ns == '.') $ns =''; 5643df72098SAndreas Gohr } 5653df72098SAndreas Gohr $ns = utf8_encodeFN(str_replace(':','/',$ns)); 5663df72098SAndreas Gohr 5673df72098SAndreas Gohr $data = array(); 568ee7b5a62SAndreas Gohr search($data,$conf['mediadir'],'search_index',array('ns' => $ns, 'nofiles' => true)); 5693df72098SAndreas Gohr 5703df72098SAndreas Gohr // wrap a list with the root level around the other namespaces 571256ca81eSAndreas Gohr $item = array( 'level' => 0, 'id' => '', 572256ca81eSAndreas Gohr 'open' =>'true', 'label' => '['.$lang['mediaroot'].']'); 5733df72098SAndreas Gohr 5743df72098SAndreas Gohr echo '<ul class="idx">'; 5753df72098SAndreas Gohr echo media_nstree_li($item); 5763df72098SAndreas Gohr echo media_nstree_item($item); 5773df72098SAndreas Gohr echo html_buildlist($data,'idx','media_nstree_item','media_nstree_li'); 5783df72098SAndreas Gohr echo '</li>'; 5793df72098SAndreas Gohr echo '</ul>'; 5803df72098SAndreas Gohr} 5813df72098SAndreas Gohr 5823df72098SAndreas Gohr/** 5833df72098SAndreas Gohr * Userfunction for html_buildlist 5843df72098SAndreas Gohr * 5853df72098SAndreas Gohr * Prints a media namespace tree item 5863df72098SAndreas Gohr * 5873df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 5883df72098SAndreas Gohr */ 5893df72098SAndreas Gohrfunction media_nstree_item($item){ 5903df72098SAndreas Gohr $pos = strrpos($item['id'], ':'); 5913df72098SAndreas Gohr $label = substr($item['id'], $pos > 0 ? $pos + 1 : 0); 5923df72098SAndreas Gohr if(!$item['label']) $item['label'] = $label; 5933df72098SAndreas Gohr 5943df72098SAndreas Gohr $ret = ''; 5953df72098SAndreas Gohr $ret .= '<a href="'.DOKU_BASE.'lib/exe/mediamanager.php?ns='.idfilter($item['id']).'" class="idx_dir">'; 5963df72098SAndreas Gohr $ret .= $item['label']; 5973df72098SAndreas Gohr $ret .= '</a>'; 5983df72098SAndreas Gohr return $ret; 5993df72098SAndreas Gohr} 6003df72098SAndreas Gohr 6013df72098SAndreas Gohr/** 6023df72098SAndreas Gohr * Userfunction for html_buildlist 6033df72098SAndreas Gohr * 6043df72098SAndreas Gohr * Prints a media namespace tree item opener 6053df72098SAndreas Gohr * 6063df72098SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 6073df72098SAndreas Gohr */ 6083df72098SAndreas Gohrfunction media_nstree_li($item){ 6093df72098SAndreas Gohr $class='media level'.$item['level']; 6103df72098SAndreas Gohr if($item['open']){ 6113df72098SAndreas Gohr $class .= ' open'; 6123df72098SAndreas Gohr $img = DOKU_BASE.'lib/images/minus.gif'; 6137af1b404SAnika Henke $alt = '−'; 6143df72098SAndreas Gohr }else{ 6153df72098SAndreas Gohr $class .= ' closed'; 6163df72098SAndreas Gohr $img = DOKU_BASE.'lib/images/plus.gif'; 6177af1b404SAnika Henke $alt = '+'; 6183df72098SAndreas Gohr } 6193df72098SAndreas Gohr return '<li class="'.$class.'">'. 6207af1b404SAnika Henke '<img src="'.$img.'" alt="'.$alt.'" />'; 6213df72098SAndreas Gohr} 622