1b625487dSandi<?php 2b625487dSandi/** 3b625487dSandi * Utilities for handling pagenames 4b625487dSandi * 5b625487dSandi * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 6b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 7*1380fc45SAndreas Gohr * @todo Combine similar functions like {wiki,media,meta}FN() 8b625487dSandi */ 9b625487dSandi 106c7843b5Sandi/** 116c7843b5Sandi * Fetch the pageid 126c7843b5Sandi * 136c7843b5Sandi * Uses either standard $_REQUEST variable or extracts it from 146c7843b5Sandi * the full request URI when userewrite is set to 2 156c7843b5Sandi * 166c7843b5Sandi * Returns $conf['start'] if no id was found. 176c7843b5Sandi * 186c7843b5Sandi * @author Andreas Gohr <andi@splitbrain.org> 196c7843b5Sandi */ 206c7843b5Sandifunction getID(){ 216c7843b5Sandi global $conf; 226c7843b5Sandi 236c7843b5Sandi $id = cleanID($_REQUEST['id']); 246c7843b5Sandi 256c7843b5Sandi //construct page id from request URI 266c7843b5Sandi if(empty($id) && $conf['userewrite'] == 2){ 276c7843b5Sandi //get the script URL 286c7843b5Sandi if($conf['basedir']){ 296c7843b5Sandi $script = $conf['basedir'].DOKU_SCRIPT; 306c7843b5Sandi }elseif($_SERVER['DOCUMENT_ROOT'] && $_SERVER['SCRIPT_FILENAME']){ 316c7843b5Sandi $script = preg_replace ('/^'.preg_quote($_SERVER['DOCUMENT_ROOT'],'/').'/','', 326c7843b5Sandi $_SERVER['SCRIPT_FILENAME']); 336c7843b5Sandi $script = '/'.$script; 346c7843b5Sandi }else{ 356c7843b5Sandi $script = $_SERVER['SCRIPT_NAME']; 366c7843b5Sandi } 376c7843b5Sandi 3852339126Sandi //clean script and request (fixes a windows problem) 3952339126Sandi $script = preg_replace('/\/\/+/','/',$script); 4052339126Sandi $request = preg_replace('/\/\/+/','/',$_SERVER['REQUEST_URI']); 4152339126Sandi 426c7843b5Sandi //remove script URL and Querystring to gain the id 4352339126Sandi if(preg_match('/^'.preg_quote($script,'/').'(.*)/',$request, $match)){ 446c7843b5Sandi $id = preg_replace ('/\?.*/','',$match[1]); 456c7843b5Sandi } 466c7843b5Sandi $id = cleanID($id); 476c7843b5Sandi } 486c7843b5Sandi if(empty($id)) $id = $conf['start']; 496c7843b5Sandi 506c7843b5Sandi return $id; 516c7843b5Sandi} 52b625487dSandi 53b625487dSandi/** 54b625487dSandi * Remove unwanted chars from ID 55b625487dSandi * 56b625487dSandi * Cleans a given ID to only use allowed characters. Accented characters are 57b625487dSandi * converted to unaccented ones 58b625487dSandi * 59b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 60b625487dSandi */ 61b625487dSandifunction cleanID($id){ 62b625487dSandi global $conf; 63b625487dSandi global $lang; 64b625487dSandi $id = trim($id); 65b625487dSandi $id = utf8_strtolower($id); 66b625487dSandi 67b625487dSandi //alternative namespace seperator 68b625487dSandi $id = strtr($id,';',':'); 69b625487dSandi if($conf['useslash']){ 70b625487dSandi $id = strtr($id,'/',':'); 71b625487dSandi }else{ 72b625487dSandi $id = strtr($id,'/','_'); 73b625487dSandi } 74b625487dSandi 75b625487dSandi if($conf['deaccent']) $id = utf8_deaccent($id,-1); 76b625487dSandi 77b625487dSandi //remove specials 785c812709Sandi $id = utf8_stripspecials($id,'_'); 79b625487dSandi 80b625487dSandi //clean up 8106bd9a88Sandi $id = preg_replace('#_+#','_',$id); 82b625487dSandi $id = preg_replace('#:+#',':',$id); 83b625487dSandi $id = trim($id,':._-'); 84b625487dSandi $id = preg_replace('#:[:\._\-]+#',':',$id); 85b625487dSandi 86b625487dSandi return($id); 87b625487dSandi} 88b625487dSandi 89b625487dSandi/** 90b625487dSandi * Return namespacepart of a wiki ID 91b625487dSandi * 92b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 93b625487dSandi */ 94b625487dSandifunction getNS($id){ 95b625487dSandi if(strpos($id,':')!==false){ 96b625487dSandi return substr($id,0,strrpos($id,':')); 97b625487dSandi } 98b625487dSandi return false; 99b625487dSandi} 100b625487dSandi 101b625487dSandi/** 102b625487dSandi * Returns the ID without the namespace 103b625487dSandi * 104b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 105b625487dSandi */ 106b625487dSandifunction noNS($id){ 107b625487dSandi return preg_replace('/.*:/','',$id); 108b625487dSandi} 109b625487dSandi 110b625487dSandi/** 111b625487dSandi * returns the full path to the datafile specified by ID and 112b625487dSandi * optional revision 113b625487dSandi * 114b625487dSandi * The filename is URL encoded to protect Unicode chars 115b625487dSandi * 116b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 117b625487dSandi */ 118b625487dSandifunction wikiFN($id,$rev=''){ 119b625487dSandi global $conf; 120b625487dSandi $id = cleanID($id); 121b625487dSandi $id = str_replace(':','/',$id); 122b625487dSandi if(empty($rev)){ 123b625487dSandi $fn = $conf['datadir'].'/'.utf8_encodeFN($id).'.txt'; 124b625487dSandi }else{ 125b625487dSandi $fn = $conf['olddir'].'/'.utf8_encodeFN($id).'.'.$rev.'.txt'; 126b625487dSandi if($conf['usegzip'] && !@file_exists($fn)){ 127b625487dSandi //return gzip if enabled and plaintext doesn't exist 128b625487dSandi $fn .= '.gz'; 129b625487dSandi } 130b625487dSandi } 131b625487dSandi return $fn; 132b625487dSandi} 133b625487dSandi 134b625487dSandi/** 135*1380fc45SAndreas Gohr * returns the full path to the meta file specified by ID and extension 136b158d625SSteven Danz * 137b158d625SSteven Danz * The filename is URL encoded to protect Unicode chars 138b158d625SSteven Danz * 139b158d625SSteven Danz * @author Steven Danz <steven-danz@kc.rr.com> 140b158d625SSteven Danz */ 141*1380fc45SAndreas Gohrfunction metaFN($id,$ext){ 142b158d625SSteven Danz global $conf; 143b158d625SSteven Danz $id = cleanID($id); 144b158d625SSteven Danz $id = str_replace(':','/',$id); 145*1380fc45SAndreas Gohr $fn = $conf['metadir'].'/'.utf8_encodeFN($id).$ext; 146b158d625SSteven Danz return $fn; 147b158d625SSteven Danz} 148b158d625SSteven Danz 149b158d625SSteven Danz/** 150b625487dSandi * returns the full path to the mediafile specified by ID 151b625487dSandi * 152b625487dSandi * The filename is URL encoded to protect Unicode chars 153b625487dSandi * 154b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 155b625487dSandi */ 156b625487dSandifunction mediaFN($id){ 157b625487dSandi global $conf; 158b625487dSandi $id = cleanID($id); 159b625487dSandi $id = str_replace(':','/',$id); 160b625487dSandi $fn = $conf['mediadir'].'/'.utf8_encodeFN($id); 161b625487dSandi return $fn; 162b625487dSandi} 163b625487dSandi 164b625487dSandi/** 165b625487dSandi * Returns the full filepath to a localized textfile if local 166b625487dSandi * version isn't found the english one is returned 167b625487dSandi * 168b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 169b625487dSandi */ 170b625487dSandifunction localeFN($id){ 171b625487dSandi global $conf; 172bc3b6aecSandi $file = DOKU_INC.'inc/lang/'.$conf['lang'].'/'.$id.'.txt'; 173b625487dSandi if(!@file_exists($file)){ 174b625487dSandi //fall back to english 175bc3b6aecSandi $file = DOKU_INC.'inc/lang/en/'.$id.'.txt'; 176b625487dSandi } 177b625487dSandi return $file; 178b625487dSandi} 179b625487dSandi 180b625487dSandi/** 181b625487dSandi * Returns a full media id 182b625487dSandi * 183b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 184b625487dSandi */ 18537e34a5eSandifunction resolve_mediaid($ns,&$page,&$exists){ 186b625487dSandi global $conf; 18737e34a5eSandi 188b625487dSandi //if links starts with . add current namespace 189b625487dSandi if($page{0} == '.'){ 190b625487dSandi $page = $ns.':'.substr($page,1); 191b625487dSandi } 192b625487dSandi 193b625487dSandi //if link contains no namespace. add current namespace (if any) 194b625487dSandi if($ns !== false && strpos($page,':') === false){ 195b625487dSandi $page = $ns.':'.$page; 196b625487dSandi } 197b625487dSandi 198b625487dSandi $page = cleanID($page); 199b625487dSandi $file = mediaFN($page); 200b625487dSandi $exists = @file_exists($file); 201b625487dSandi} 202b625487dSandi 203b625487dSandi/** 204b625487dSandi * Returns a full page id 205b625487dSandi * 206b625487dSandi * @author Andreas Gohr <andi@splitbrain.org> 207b625487dSandi */ 20837e34a5eSandifunction resolve_pageid($ns,&$page,&$exists){ 209b625487dSandi global $conf; 2100b7c14c2Sandi $exists = false; 211b625487dSandi 212b625487dSandi //if links starts with . add current namespace 213b625487dSandi if($page{0} == '.'){ 214b625487dSandi $page = $ns.':'.substr($page,1); 215b625487dSandi } 216b625487dSandi 217b625487dSandi //if link contains no namespace. add current namespace (if any) 218b625487dSandi if($ns !== false && strpos($page,':') === false){ 219b625487dSandi $page = $ns.':'.$page; 220b625487dSandi } 221b625487dSandi 222b625487dSandi //keep hashlink if exists then clean both parts 223b625487dSandi list($page,$hash) = split('#',$page,2); 224b625487dSandi $page = cleanID($page); 225b625487dSandi $hash = cleanID($hash); 226b625487dSandi 227b625487dSandi $file = wikiFN($page); 228b625487dSandi 229b625487dSandi //check alternative plural/nonplural form 230b625487dSandi if(!@file_exists($file)){ 231b625487dSandi if( $conf['autoplural'] ){ 232b625487dSandi if(substr($page,-1) == 's'){ 233b625487dSandi $try = substr($page,0,-1); 234b625487dSandi }else{ 235b625487dSandi $try = $page.'s'; 236b625487dSandi } 237b625487dSandi if(@file_exists(wikiFN($try))){ 238b625487dSandi $page = $try; 239b625487dSandi $exists = true; 240b625487dSandi } 241b625487dSandi } 242b625487dSandi }else{ 243b625487dSandi $exists = true; 244b625487dSandi } 245b625487dSandi 246b625487dSandi //add hash if any 247b2d7d3f2Sandi if(!empty($hash)) $page .= '#'.$hash; 248b625487dSandi} 249b625487dSandi 25098407a7aSandi/** 25198407a7aSandi * Returns the name of a cachefile from given data 25298407a7aSandi * 25398407a7aSandi * The needed directory is created by this function! 25498407a7aSandi * 25598407a7aSandi * @author Andreas Gohr <andi@splitbrain.org> 25698407a7aSandi * 25798407a7aSandi * @param string $data This data is used to create a unique md5 name 25898407a7aSandi * @param string $ext This is appended to the filename if given 25998407a7aSandi * @return string The filename of the cachefile 26098407a7aSandi */ 26198407a7aSandifunction getCacheName($data,$ext=''){ 26298407a7aSandi global $conf; 26398407a7aSandi $md5 = md5($data); 26498407a7aSandi $file = $conf['cachedir'].'/'.$md5{0}.'/'.$md5.$ext; 26598407a7aSandi io_makeFileDir($file); 26698407a7aSandi return $file; 26798407a7aSandi} 26898407a7aSandi 269b625487dSandi//Setup VIM: ex: et ts=2 enc=utf-8 : 270