16b13307fSandi<?php 26b13307fSandi/** 36b13307fSandi * DokuWiki Actions 46b13307fSandi * 56b13307fSandi * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 66b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 76b13307fSandi */ 86b13307fSandi 9fa8adffeSAndreas Gohrif(!defined('DOKU_INC')) die('meh.'); 10af182434Sandi 116b13307fSandi/** 126b13307fSandi * Call the needed action handlers 136b13307fSandi * 146b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 15c9570649SAndreas Gohr * @triggers ACTION_ACT_PREPROCESS 16c9570649SAndreas Gohr * @triggers ACTION_HEADERS_SEND 176b13307fSandi */ 186b13307fSandifunction act_dispatch(){ 196b13307fSandi global $INFO; 206b13307fSandi global $ACT; 216b13307fSandi global $ID; 226b13307fSandi global $QUERY; 236b13307fSandi global $lang; 246b13307fSandi global $conf; 25066fee30SAndreas Gohr global $license; 266b13307fSandi 2769cd1e27SAndreas Gohr $preact = $ACT; 2869cd1e27SAndreas Gohr 29c2e830f2Schris // give plugins an opportunity to process the action 3024bb549bSchris $evt = new Doku_Event('ACTION_ACT_PREPROCESS',$ACT); 3124bb549bSchris if ($evt->advise_before()) { 32c2e830f2Schris 33af182434Sandi //sanitize $ACT 34af182434Sandi $ACT = act_clean($ACT); 35af182434Sandi 36b8957367SBenjamin Gilbert //check if searchword was given - else just show 370868021bSAndreas Gohr $s = cleanID($QUERY); 380868021bSAndreas Gohr if($ACT == 'search' && empty($s)){ 39b8957367SBenjamin Gilbert $ACT = 'show'; 40b8957367SBenjamin Gilbert } 41b8957367SBenjamin Gilbert 42b8957367SBenjamin Gilbert //login stuff 431b2a85e8SAndreas Gohr if(in_array($ACT,array('login','logout'))){ 44b8957367SBenjamin Gilbert $ACT = act_auth($ACT); 451b2a85e8SAndreas Gohr } 46b8957367SBenjamin Gilbert 471380fc45SAndreas Gohr //check if user is asking to (un)subscribe a page 485b75cd1fSAdrian Lang if($ACT == 'subscribe') { 495b75cd1fSAdrian Lang try { 501380fc45SAndreas Gohr $ACT = act_subscription($ACT); 515b75cd1fSAdrian Lang } catch (Exception $e) { 525b75cd1fSAdrian Lang msg($e->getMessage(), -1); 535b75cd1fSAdrian Lang } 545b75cd1fSAdrian Lang } 5552b0dd67SGuy Brand 566b13307fSandi //check permissions 576b13307fSandi $ACT = act_permcheck($ACT); 586b13307fSandi 59b8957367SBenjamin Gilbert //register 60c9570649SAndreas Gohr $nil = array(); 61b3510079SAndreas Gohr if($ACT == 'register' && $_POST['save'] && register()){ 62b8957367SBenjamin Gilbert $ACT = 'login'; 63b8957367SBenjamin Gilbert } 646b13307fSandi 658b06d178Schris if ($ACT == 'resendpwd' && act_resendpwd()) { 668b06d178Schris $ACT = 'login'; 678b06d178Schris } 688b06d178Schris 698b06d178Schris //update user profile 7025b2a98cSMichael Klier if ($ACT == 'profile') { 7125b2a98cSMichael Klier if(!$_SERVER['REMOTE_USER']) { 7225b2a98cSMichael Klier $ACT = 'login'; 7325b2a98cSMichael Klier } else { 7425b2a98cSMichael Klier if(updateprofile()) { 754cb79657SMatthias Grimm msg($lang['profchanged'],1); 764cb79657SMatthias Grimm $ACT = 'show'; 778b06d178Schris } 7825b2a98cSMichael Klier } 7925b2a98cSMichael Klier } 808b06d178Schris 811246e016SAndreas Gohr //revert 821246e016SAndreas Gohr if($ACT == 'revert'){ 831246e016SAndreas Gohr if(checkSecurityToken()){ 841246e016SAndreas Gohr $ACT = act_revert($ACT); 851246e016SAndreas Gohr }else{ 861246e016SAndreas Gohr $ACT = 'show'; 871246e016SAndreas Gohr } 881246e016SAndreas Gohr } 891246e016SAndreas Gohr 906b13307fSandi //save 911b2a85e8SAndreas Gohr if($ACT == 'save'){ 921b2a85e8SAndreas Gohr if(checkSecurityToken()){ 936b13307fSandi $ACT = act_save($ACT); 941b2a85e8SAndreas Gohr }else{ 951b2a85e8SAndreas Gohr $ACT = 'show'; 961b2a85e8SAndreas Gohr } 971b2a85e8SAndreas Gohr } 986b13307fSandi 99067c5d22SBen Coburn //cancel conflicting edit 100067c5d22SBen Coburn if($ACT == 'cancel') 101067c5d22SBen Coburn $ACT = 'show'; 102067c5d22SBen Coburn 103ee4c4a1bSAndreas Gohr //draft deletion 104ee4c4a1bSAndreas Gohr if($ACT == 'draftdel') 105ee4c4a1bSAndreas Gohr $ACT = act_draftdel($ACT); 106ee4c4a1bSAndreas Gohr 107ee4c4a1bSAndreas Gohr //draft saving on preview 108ee4c4a1bSAndreas Gohr if($ACT == 'preview') 109ee4c4a1bSAndreas Gohr $ACT = act_draftsave($ACT); 110ee4c4a1bSAndreas Gohr 1116b13307fSandi //edit 112*c9d5430bSAdrian Lang if(in_array($ACT, array('edit', 'preview', 'recover'))) { 113af182434Sandi $ACT = act_edit($ACT); 1146b13307fSandi }else{ 1156b13307fSandi unlock($ID); //try to unlock 1166b13307fSandi } 1176b13307fSandi 1186b13307fSandi //handle export 119ac83b9d8Sandi if(substr($ACT,0,7) == 'export_') 1206b13307fSandi $ACT = act_export($ACT); 1216b13307fSandi 1226b13307fSandi //display some infos 1236b13307fSandi if($ACT == 'check'){ 1246b13307fSandi check(); 1256b13307fSandi $ACT = 'show'; 1266b13307fSandi } 1276b13307fSandi 128c19fe9c0Sandi //handle admin tasks 129c19fe9c0Sandi if($ACT == 'admin'){ 13011e2ce22Schris // retrieve admin plugin name from $_REQUEST['page'] 131bb4866bdSchris if (!empty($_REQUEST['page'])) { 13211e2ce22Schris $pluginlist = plugin_list('admin'); 13311e2ce22Schris if (in_array($_REQUEST['page'], $pluginlist)) { 13411e2ce22Schris // attempt to load the plugin 13549eb6e38SAndreas Gohr if ($plugin =& plugin_load('admin',$_REQUEST['page']) !== null) 13611e2ce22Schris $plugin->handle(); 13711e2ce22Schris } 13811e2ce22Schris } 139c19fe9c0Sandi } 1405f312bacSAndreas Gohr 1415f312bacSAndreas Gohr // check permissions again - the action may have changed 1425f312bacSAndreas Gohr $ACT = act_permcheck($ACT); 14324bb549bSchris } // end event ACTION_ACT_PREPROCESS default action 14424bb549bSchris $evt->advise_after(); 14524bb549bSchris unset($evt); 146c19fe9c0Sandi 14746c0ed74SMichael Hamann // when action 'show', the intial not 'show' and POST, do a redirect 14846c0ed74SMichael Hamann if($ACT == 'show' && $preact != 'show' && strtolower($_SERVER['REQUEST_METHOD']) == 'post'){ 14969cd1e27SAndreas Gohr act_redirect($ID,$preact); 15069cd1e27SAndreas Gohr } 1515f312bacSAndreas Gohr 1526b13307fSandi //call template FIXME: all needed vars available? 153f63a2007Schris $headers[] = 'Content-Type: text/html; charset=utf-8'; 154746855cfSBen Coburn trigger_event('ACTION_HEADERS_SEND',$headers,'act_sendheaders'); 155f63a2007Schris 1565a892029SAndreas Gohr include(template('main.php')); 157c19fe9c0Sandi // output for the commands is now handled in inc/templates.php 158c19fe9c0Sandi // in function tpl_content() 1596b13307fSandi} 1606b13307fSandi 161f63a2007Schrisfunction act_sendheaders($headers) { 162f63a2007Schris foreach ($headers as $hdr) header($hdr); 163f63a2007Schris} 164f63a2007Schris 1656b13307fSandi/** 166af182434Sandi * Sanitize the action command 167af182434Sandi * 168af182434Sandi * Add all allowed commands here. 169af182434Sandi * 170af182434Sandi * @author Andreas Gohr <andi@splitbrain.org> 171af182434Sandi */ 172af182434Sandifunction act_clean($act){ 173af182434Sandi global $lang; 17460e6b550SAndreas Gohr global $conf; 175af182434Sandi 176ee4c4a1bSAndreas Gohr // check if the action was given as array key 177ee4c4a1bSAndreas Gohr if(is_array($act)){ 178ee4c4a1bSAndreas Gohr list($act) = array_keys($act); 179ee4c4a1bSAndreas Gohr } 180ee4c4a1bSAndreas Gohr 181ac83b9d8Sandi //remove all bad chars 182ac83b9d8Sandi $act = strtolower($act); 1832d5ccb39SAndreas Gohr $act = preg_replace('/[^1-9a-z_]+/','',$act); 184ac83b9d8Sandi 185ac83b9d8Sandi if($act == 'export_html') $act = 'export_xhtml'; 186cc2ae802SAndreas Gohr if($act == 'export_htmlbody') $act = 'export_xhtmlbody'; 187b146b32bSandi 188409d7af7SAndreas Gohr // check if action is disabled 189409d7af7SAndreas Gohr if(!actionOK($act)){ 190409d7af7SAndreas Gohr msg('Command disabled: '.htmlspecialchars($act),-1); 191409d7af7SAndreas Gohr return 'show'; 192409d7af7SAndreas Gohr } 193409d7af7SAndreas Gohr 19460e6b550SAndreas Gohr //disable all acl related commands if ACL is disabled 19560e6b550SAndreas Gohr if(!$conf['useacl'] && in_array($act,array('login','logout','register','admin', 1961246e016SAndreas Gohr 'subscribe','unsubscribe','profile','revert', 19752b0dd67SGuy Brand 'resendpwd','subscribens','unsubscribens',))){ 19860e6b550SAndreas Gohr msg('Command unavailable: '.htmlspecialchars($act),-1); 19960e6b550SAndreas Gohr return 'show'; 20060e6b550SAndreas Gohr } 20160e6b550SAndreas Gohr 202067c5d22SBen Coburn if(!in_array($act,array('login','logout','register','save','cancel','edit','draft', 203ac83b9d8Sandi 'preview','search','show','check','index','revisions', 2041246e016SAndreas Gohr 'diff','recent','backlink','admin','subscribe','revert', 2055a932e77SAdrian Lang 'unsubscribe','profile','resendpwd','recover', 20652b0dd67SGuy Brand 'draftdel','subscribens','unsubscribens',)) && substr($act,0,7) != 'export_' ) { 207ee4c4a1bSAndreas Gohr msg('Command unknown: '.htmlspecialchars($act),-1); 208af182434Sandi return 'show'; 209af182434Sandi } 210af182434Sandi return $act; 211af182434Sandi} 212af182434Sandi 213af182434Sandi/** 2146b13307fSandi * Run permissionchecks 2156b13307fSandi * 2166b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 2176b13307fSandi */ 2186b13307fSandifunction act_permcheck($act){ 219dbbc6aa7Sandi global $INFO; 2205e199953Smatthiasgrimm global $conf; 221dbbc6aa7Sandi 222ee4c4a1bSAndreas Gohr if(in_array($act,array('save','preview','edit','recover'))){ 2236b13307fSandi if($INFO['exists']){ 224bdbc16bfSandi if($act == 'edit'){ 225bdbc16bfSandi //the edit function will check again and do a source show 226bdbc16bfSandi //when no AUTH_EDIT available 227bdbc16bfSandi $permneed = AUTH_READ; 228bdbc16bfSandi }else{ 2296b13307fSandi $permneed = AUTH_EDIT; 230bdbc16bfSandi } 2316b13307fSandi }else{ 2326b13307fSandi $permneed = AUTH_CREATE; 2336b13307fSandi } 2348b06d178Schris }elseif(in_array($act,array('login','search','recent','profile'))){ 2356b13307fSandi $permneed = AUTH_NONE; 2361246e016SAndreas Gohr }elseif($act == 'revert'){ 2371246e016SAndreas Gohr $permneed = AUTH_ADMIN; 2381246e016SAndreas Gohr if($INFO['ismanager']) $permneed = AUTH_EDIT; 2395e199953Smatthiasgrimm }elseif($act == 'register'){ 2405e199953Smatthiasgrimm $permneed = AUTH_NONE; 241ebd3d9ceSchris }elseif($act == 'resendpwd'){ 242ebd3d9ceSchris $permneed = AUTH_NONE; 243c19fe9c0Sandi }elseif($act == 'admin'){ 244f8cc712eSAndreas Gohr if($INFO['ismanager']){ 245f8cc712eSAndreas Gohr // if the manager has the needed permissions for a certain admin 246f8cc712eSAndreas Gohr // action is checked later 247f8cc712eSAndreas Gohr $permneed = AUTH_READ; 248f8cc712eSAndreas Gohr }else{ 249c19fe9c0Sandi $permneed = AUTH_ADMIN; 250f8cc712eSAndreas Gohr } 2516b13307fSandi }else{ 2526b13307fSandi $permneed = AUTH_READ; 2536b13307fSandi } 254dbbc6aa7Sandi if($INFO['perm'] >= $permneed) return $act; 255dbbc6aa7Sandi 2566b13307fSandi return 'denied'; 2576b13307fSandi} 2586b13307fSandi 2596b13307fSandi/** 260ee4c4a1bSAndreas Gohr * Handle 'draftdel' 261ee4c4a1bSAndreas Gohr * 262ee4c4a1bSAndreas Gohr * Deletes the draft for the current page and user 263ee4c4a1bSAndreas Gohr */ 264ee4c4a1bSAndreas Gohrfunction act_draftdel($act){ 265ee4c4a1bSAndreas Gohr global $INFO; 266ee4c4a1bSAndreas Gohr @unlink($INFO['draft']); 267ee4c4a1bSAndreas Gohr $INFO['draft'] = null; 268ee4c4a1bSAndreas Gohr return 'show'; 269ee4c4a1bSAndreas Gohr} 270ee4c4a1bSAndreas Gohr 271ee4c4a1bSAndreas Gohr/** 272ee4c4a1bSAndreas Gohr * Saves a draft on preview 273ee4c4a1bSAndreas Gohr * 274ee4c4a1bSAndreas Gohr * @todo this currently duplicates code from ajax.php :-/ 275ee4c4a1bSAndreas Gohr */ 276ee4c4a1bSAndreas Gohrfunction act_draftsave($act){ 277ee4c4a1bSAndreas Gohr global $INFO; 278ee4c4a1bSAndreas Gohr global $ID; 279ee4c4a1bSAndreas Gohr global $conf; 280ee4c4a1bSAndreas Gohr if($conf['usedraft'] && $_POST['wikitext']){ 281ee4c4a1bSAndreas Gohr $draft = array('id' => $ID, 282ee4c4a1bSAndreas Gohr 'prefix' => $_POST['prefix'], 283ee4c4a1bSAndreas Gohr 'text' => $_POST['wikitext'], 284ee4c4a1bSAndreas Gohr 'suffix' => $_POST['suffix'], 285ee4c4a1bSAndreas Gohr 'date' => $_POST['date'], 286ee4c4a1bSAndreas Gohr 'client' => $INFO['client'], 287ee4c4a1bSAndreas Gohr ); 288ee4c4a1bSAndreas Gohr $cname = getCacheName($draft['client'].$ID,'.draft'); 289ee4c4a1bSAndreas Gohr if(io_saveFile($cname,serialize($draft))){ 290ee4c4a1bSAndreas Gohr $INFO['draft'] = $cname; 291ee4c4a1bSAndreas Gohr } 292ee4c4a1bSAndreas Gohr } 293ee4c4a1bSAndreas Gohr return $act; 294ee4c4a1bSAndreas Gohr} 295ee4c4a1bSAndreas Gohr 296ee4c4a1bSAndreas Gohr/** 2976b13307fSandi * Handle 'save' 2986b13307fSandi * 2996b13307fSandi * Checks for spam and conflicts and saves the page. 3006b13307fSandi * Does a redirect to show the page afterwards or 3016b13307fSandi * returns a new action. 3026b13307fSandi * 3036b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 3046b13307fSandi */ 3056b13307fSandifunction act_save($act){ 3066b13307fSandi global $ID; 3076b13307fSandi global $DATE; 3086b13307fSandi global $PRE; 3096b13307fSandi global $TEXT; 3106b13307fSandi global $SUF; 3116b13307fSandi global $SUM; 3125a932e77SAdrian Lang global $lang; 3138d67c48aSAdrian Lang global $INFO; 3146b13307fSandi 3156b13307fSandi //spam check 3165a932e77SAdrian Lang if(checkwordblock()) { 3175a932e77SAdrian Lang msg($lang['wordblock'], -1); 3185a932e77SAdrian Lang return 'edit'; 3195a932e77SAdrian Lang } 3208d67c48aSAdrian Lang //conflict check 3218d67c48aSAdrian Lang if($DATE != 0 && $INFO['meta']['date']['modified'] > $DATE ) 3226b13307fSandi return 'conflict'; 3236b13307fSandi 3246b13307fSandi //save it 325b6912aeaSAndreas Gohr saveWikiText($ID,con($PRE,$TEXT,$SUF,1),$SUM,$_REQUEST['minor']); //use pretty mode for con 3266b13307fSandi //unlock it 3276b13307fSandi unlock($ID); 3286b13307fSandi 329ee4c4a1bSAndreas Gohr //delete draft 330ee4c4a1bSAndreas Gohr act_draftdel($act); 33169cd1e27SAndreas Gohr session_write_close(); 332ee4c4a1bSAndreas Gohr 33369cd1e27SAndreas Gohr // when done, show page 33469cd1e27SAndreas Gohr return 'show'; 33569cd1e27SAndreas Gohr} 336f951a474SAndreas Gohr 33714a122deSAndreas Gohr/** 3381246e016SAndreas Gohr * Revert to a certain revision 3391246e016SAndreas Gohr * 3401246e016SAndreas Gohr * @author Andreas Gohr <andi@splitbrain.org> 3411246e016SAndreas Gohr */ 3421246e016SAndreas Gohrfunction act_revert($act){ 3431246e016SAndreas Gohr global $ID; 3441246e016SAndreas Gohr global $REV; 3451246e016SAndreas Gohr global $lang; 3461246e016SAndreas Gohr 3471246e016SAndreas Gohr // when no revision is given, delete current one 3481246e016SAndreas Gohr // FIXME this feature is not exposed in the GUI currently 3491246e016SAndreas Gohr $text = ''; 3501246e016SAndreas Gohr $sum = $lang['deleted']; 3511246e016SAndreas Gohr if($REV){ 3521246e016SAndreas Gohr $text = rawWiki($ID,$REV); 3531246e016SAndreas Gohr if(!$text) return 'show'; //something went wrong 3541246e016SAndreas Gohr $sum = $lang['restored']; 3551246e016SAndreas Gohr } 3561246e016SAndreas Gohr 3571246e016SAndreas Gohr // spam check 3585a932e77SAdrian Lang 3595a932e77SAdrian Lang if (checkwordblock($text)) { 3605a932e77SAdrian Lang msg($lang['wordblock'], -1); 3615a932e77SAdrian Lang return 'edit'; 3625a932e77SAdrian Lang } 3631246e016SAndreas Gohr 3641246e016SAndreas Gohr saveWikiText($ID,$text,$sum,false); 3651246e016SAndreas Gohr msg($sum,1); 3661246e016SAndreas Gohr 3671246e016SAndreas Gohr //delete any draft 3681246e016SAndreas Gohr act_draftdel($act); 3691246e016SAndreas Gohr session_write_close(); 3701246e016SAndreas Gohr 3711246e016SAndreas Gohr // when done, show current page 3721246e016SAndreas Gohr $_SERVER['REQUEST_METHOD'] = 'post'; //should force a redirect 3731246e016SAndreas Gohr $REV = ''; 3741246e016SAndreas Gohr return 'show'; 3751246e016SAndreas Gohr} 3761246e016SAndreas Gohr 3771246e016SAndreas Gohr/** 37814a122deSAndreas Gohr * Do a redirect after receiving post data 37914a122deSAndreas Gohr * 38014a122deSAndreas Gohr * Tries to add the section id as hash mark after section editing 38114a122deSAndreas Gohr */ 38269cd1e27SAndreas Gohrfunction act_redirect($id,$preact){ 38369cd1e27SAndreas Gohr global $PRE; 38469cd1e27SAndreas Gohr global $TEXT; 38514a122deSAndreas Gohr global $MSG; 38614a122deSAndreas Gohr 38714a122deSAndreas Gohr //are there any undisplayed messages? keep them in session for display 38814a122deSAndreas Gohr //on the next page 38914a122deSAndreas Gohr if(isset($MSG) && count($MSG)){ 39014a122deSAndreas Gohr //reopen session, store data and close session again 39114a122deSAndreas Gohr @session_start(); 39214a122deSAndreas Gohr $_SESSION[DOKU_COOKIE]['msg'] = $MSG; 39314a122deSAndreas Gohr session_write_close(); 39414a122deSAndreas Gohr } 395f951a474SAndreas Gohr 39669cd1e27SAndreas Gohr $opts = array( 39769cd1e27SAndreas Gohr 'id' => $id, 39869cd1e27SAndreas Gohr 'preact' => $preact 39969cd1e27SAndreas Gohr ); 400c66972f2SAdrian Lang //get section name when coming from section edit 401c66972f2SAdrian Lang if($PRE && preg_match('/^\s*==+([^=\n]+)/',$TEXT,$match)){ 402c66972f2SAdrian Lang $check = false; //Byref 403c66972f2SAdrian Lang $opts['fragment'] = sectionID($match[0], $check); 404c66972f2SAdrian Lang } 405c66972f2SAdrian Lang 40669cd1e27SAndreas Gohr trigger_event('ACTION_SHOW_REDIRECT',$opts,'act_redirect_execute'); 40769cd1e27SAndreas Gohr} 40869cd1e27SAndreas Gohr 40969cd1e27SAndreas Gohrfunction act_redirect_execute($opts){ 41069cd1e27SAndreas Gohr $go = wl($opts['id'],'',true); 411c66972f2SAdrian Lang if(isset($opts['fragment'])) $go .= '#'.$opts['fragment']; 41269cd1e27SAndreas Gohr 4136b13307fSandi //show it 414af2408d5SAndreas Gohr send_redirect($go); 4156b13307fSandi} 4166b13307fSandi 4176b13307fSandi/** 418b8957367SBenjamin Gilbert * Handle 'login', 'logout' 4196b13307fSandi * 4206b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 4216b13307fSandi */ 4226b13307fSandifunction act_auth($act){ 42308eda5bcSmatthiasgrimm global $ID; 4247cace34dSAndreas Gohr global $INFO; 42508eda5bcSmatthiasgrimm 4266b13307fSandi //already logged in? 427c66972f2SAdrian Lang if(isset($_SERVER['REMOTE_USER']) && $act=='login'){ 428ca12ce46SAndreas Gohr return 'show'; 4292288dc06SGuy Brand } 4306b13307fSandi 4316b13307fSandi //handle logout 4326b13307fSandi if($act=='logout'){ 43308eda5bcSmatthiasgrimm $lockedby = checklock($ID); //page still locked? 434424c3c4fSJohannes Buchner if($lockedby == $_SERVER['REMOTE_USER']) 43508eda5bcSmatthiasgrimm unlock($ID); //try to unlock 43608eda5bcSmatthiasgrimm 4377cace34dSAndreas Gohr // do the logout stuff 4386b13307fSandi auth_logoff(); 4397cace34dSAndreas Gohr 4407cace34dSAndreas Gohr // rebuild info array 4417cace34dSAndreas Gohr $INFO = pageinfo(); 4427cace34dSAndreas Gohr 443e16eccb7SGuy Brand act_redirect($ID,'login'); 4446b13307fSandi } 4456b13307fSandi 4466b13307fSandi return $act; 4476b13307fSandi} 4486b13307fSandi 4496b13307fSandi/** 45045a99335SAdrian Lang * Handle 'edit', 'preview', 'recover' 4516b13307fSandi * 4526b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 4536b13307fSandi */ 4546b13307fSandifunction act_edit($act){ 455cd409024Sjorda global $ID; 456ee4c4a1bSAndreas Gohr global $INFO; 457cd409024Sjorda 45845a99335SAdrian Lang global $TEXT; 45945a99335SAdrian Lang global $RANGE; 46045a99335SAdrian Lang global $PRE; 46145a99335SAdrian Lang global $SUF; 46245a99335SAdrian Lang global $REV; 46345a99335SAdrian Lang global $SUM; 46445a99335SAdrian Lang global $lang; 46545a99335SAdrian Lang global $DATE; 46645a99335SAdrian Lang 46745a99335SAdrian Lang if (!isset($TEXT)) { 46845a99335SAdrian Lang if ($INFO['exists']) { 46945a99335SAdrian Lang if ($RANGE) { 47045a99335SAdrian Lang list($PRE,$TEXT,$SUF) = rawWikiSlices($RANGE,$ID,$REV); 47145a99335SAdrian Lang } else { 47245a99335SAdrian Lang $TEXT = rawWiki($ID,$REV); 47345a99335SAdrian Lang } 47445a99335SAdrian Lang } else { 475fe17917eSAdrian Lang $TEXT = pageTemplate($ID); 47645a99335SAdrian Lang } 47745a99335SAdrian Lang } 47845a99335SAdrian Lang 47945a99335SAdrian Lang //set summary default 48045a99335SAdrian Lang if(!$SUM){ 48145a99335SAdrian Lang if($REV){ 48245a99335SAdrian Lang $SUM = $lang['restored']; 48345a99335SAdrian Lang }elseif(!$INFO['exists']){ 48445a99335SAdrian Lang $SUM = $lang['created']; 48545a99335SAdrian Lang } 48645a99335SAdrian Lang } 48745a99335SAdrian Lang 4888d67c48aSAdrian Lang // Use the date of the newest revision, not of the revision we edit 4898d67c48aSAdrian Lang // This is used for conflict detection 4908d67c48aSAdrian Lang if(!$DATE) $DATE = $INFO['meta']['date']['modified']; 49145a99335SAdrian Lang 4926b13307fSandi //check if locked by anyone - if not lock for my self 4936b13307fSandi $lockedby = checklock($ID); 4946b13307fSandi if($lockedby) return 'locked'; 4956b13307fSandi 4966b13307fSandi lock($ID); 4976b13307fSandi return $act; 4986b13307fSandi} 4996b13307fSandi 5006b13307fSandi/** 501f6dad9fdSMichael Klier * Export a wiki page for various formats 502f6dad9fdSMichael Klier * 503f6dad9fdSMichael Klier * Triggers ACTION_EXPORT_POSTPROCESS 504f6dad9fdSMichael Klier * 505f6dad9fdSMichael Klier * Event data: 506f6dad9fdSMichael Klier * data['id'] -- page id 507f6dad9fdSMichael Klier * data['mode'] -- requested export mode 508f6dad9fdSMichael Klier * data['headers'] -- export headers 509f6dad9fdSMichael Klier * data['output'] -- export output 5106b13307fSandi * 5116b13307fSandi * @author Andreas Gohr <andi@splitbrain.org> 512f6dad9fdSMichael Klier * @author Michael Klier <chi@chimeric.de> 5136b13307fSandi */ 5146b13307fSandifunction act_export($act){ 5156b13307fSandi global $ID; 5166b13307fSandi global $REV; 51785f8705cSAnika Henke global $conf; 51885f8705cSAnika Henke global $lang; 5196b13307fSandi 520f6dad9fdSMichael Klier $pre = ''; 521f6dad9fdSMichael Klier $post = ''; 522f6dad9fdSMichael Klier $output = ''; 523f6dad9fdSMichael Klier $headers = array(); 524cc2ae802SAndreas Gohr 525f6dad9fdSMichael Klier // search engines: never cache exported docs! (Google only currently) 526f6dad9fdSMichael Klier $headers['X-Robots-Tag'] = 'noindex'; 527f6dad9fdSMichael Klier 528ac83b9d8Sandi $mode = substr($act,7); 529f6dad9fdSMichael Klier switch($mode) { 530f6dad9fdSMichael Klier case 'raw': 5315adfc5afSAnika Henke $headers['Content-Type'] = 'text/plain; charset=utf-8'; 53266b23ce9SAndreas Gohr $headers['Content-Disposition'] = 'attachment; filename='.noNS($ID).'.txt'; 533f6dad9fdSMichael Klier $output = rawWiki($ID,$REV); 534f6dad9fdSMichael Klier break; 535f6dad9fdSMichael Klier case 'xhtml': 536f6dad9fdSMichael Klier $pre .= '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"' . DOKU_LF; 537f6dad9fdSMichael Klier $pre .= ' "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">' . DOKU_LF; 538f6dad9fdSMichael Klier $pre .= '<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="'.$conf['lang'].'"' . DOKU_LF; 539f6dad9fdSMichael Klier $pre .= ' lang="'.$conf['lang'].'" dir="'.$lang['direction'].'">' . DOKU_LF; 540f6dad9fdSMichael Klier $pre .= '<head>' . DOKU_LF; 541f6dad9fdSMichael Klier $pre .= ' <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />' . DOKU_LF; 542f6dad9fdSMichael Klier $pre .= ' <title>'.$ID.'</title>' . DOKU_LF; 543f6dad9fdSMichael Klier 544f6dad9fdSMichael Klier // get metaheaders 545f6dad9fdSMichael Klier ob_start(); 546f6dad9fdSMichael Klier tpl_metaheaders(); 547f6dad9fdSMichael Klier $pre .= ob_get_clean(); 548f6dad9fdSMichael Klier 549f6dad9fdSMichael Klier $pre .= '</head>' . DOKU_LF; 550f6dad9fdSMichael Klier $pre .= '<body>' . DOKU_LF; 551f6dad9fdSMichael Klier $pre .= '<div class="dokuwiki export">' . DOKU_LF; 552f6dad9fdSMichael Klier 553f6dad9fdSMichael Klier // get toc 554f6dad9fdSMichael Klier $pre .= tpl_toc(true); 555f6dad9fdSMichael Klier 556f6dad9fdSMichael Klier $headers['Content-Type'] = 'text/html; charset=utf-8'; 557f6dad9fdSMichael Klier $output = p_wiki_xhtml($ID,$REV,false); 558f6dad9fdSMichael Klier 559f6dad9fdSMichael Klier $post .= '</div>' . DOKU_LF; 560f6dad9fdSMichael Klier $post .= '</body>' . DOKU_LF; 561f6dad9fdSMichael Klier $post .= '</html>' . DOKU_LF; 562f6dad9fdSMichael Klier break; 563f6dad9fdSMichael Klier case 'xhtmlbody': 564f6dad9fdSMichael Klier $headers['Content-Type'] = 'text/html; charset=utf-8'; 565f6dad9fdSMichael Klier $output = p_wiki_xhtml($ID,$REV,false); 566f6dad9fdSMichael Klier break; 567f6dad9fdSMichael Klier default: 568f6dad9fdSMichael Klier $output = p_cached_output(wikiFN($ID,$REV), $mode); 5699acedd40SAndreas Gohr $headers = p_get_metadata($ID,"format $mode"); 570f6dad9fdSMichael Klier break; 571f6dad9fdSMichael Klier } 572f6dad9fdSMichael Klier 573f6dad9fdSMichael Klier // prepare event data 574f6dad9fdSMichael Klier $data = array(); 575f6dad9fdSMichael Klier $data['id'] = $ID; 576f6dad9fdSMichael Klier $data['mode'] = $mode; 577f6dad9fdSMichael Klier $data['headers'] = $headers; 578f6dad9fdSMichael Klier $data['output'] =& $output; 579f6dad9fdSMichael Klier 580f6dad9fdSMichael Klier trigger_event('ACTION_EXPORT_POSTPROCESS', $data); 581f6dad9fdSMichael Klier 582f6dad9fdSMichael Klier if(!empty($data['output'])){ 583f6dad9fdSMichael Klier if(is_array($data['headers'])) foreach($data['headers'] as $key => $val){ 58485767031SAndreas Gohr header("$key: $val"); 58585767031SAndreas Gohr } 586f6dad9fdSMichael Klier print $pre.$data['output'].$post; 5876b13307fSandi exit; 5886b13307fSandi } 5896b13307fSandi return 'show'; 5906b13307fSandi} 591340756e4Sandi 592b158d625SSteven Danz/** 5935b75cd1fSAdrian Lang * Handle page 'subscribe' 594b158d625SSteven Danz * 5955b75cd1fSAdrian Lang * Throws exception on error. 5965b75cd1fSAdrian Lang * 5975b75cd1fSAdrian Lang * @author Adrian Lang <lang@cosmocode.de> 598b158d625SSteven Danz */ 5991380fc45SAndreas Gohrfunction act_subscription($act){ 600056c2049SAndreas Gohr global $lang; 601056c2049SAndreas Gohr global $INFO; 602056c2049SAndreas Gohr global $ID; 60352b0dd67SGuy Brand 604056c2049SAndreas Gohr // get and preprocess data. 6058881fcc9SAdrian Lang $params = array(); 6068881fcc9SAdrian Lang foreach(array('target', 'style', 'action') as $param) { 607056c2049SAndreas Gohr if (isset($_REQUEST["sub_$param"])) { 608056c2049SAndreas Gohr $params[$param] = $_REQUEST["sub_$param"]; 6098881fcc9SAdrian Lang } 6108881fcc9SAdrian Lang } 6118881fcc9SAdrian Lang 612056c2049SAndreas Gohr // any action given? if not just return and show the subscription page 61366d2bed9SAdrian Lang if(!$params['action'] || !checkSecurityToken()) return $act; 614056c2049SAndreas Gohr 6158881fcc9SAdrian Lang // Handle POST data, may throw exception. 6168881fcc9SAdrian Lang trigger_event('ACTION_HANDLE_SUBSCRIBE', $params, 'subscription_handle_post'); 6178881fcc9SAdrian Lang 6188881fcc9SAdrian Lang $target = $params['target']; 6198881fcc9SAdrian Lang $style = $params['style']; 6208881fcc9SAdrian Lang $data = $params['data']; 6218881fcc9SAdrian Lang $action = $params['action']; 6228881fcc9SAdrian Lang 6238881fcc9SAdrian Lang // Perform action. 6248881fcc9SAdrian Lang if (!subscription_set($_SERVER['REMOTE_USER'], $target, $style, $data)) { 6258881fcc9SAdrian Lang throw new Exception(sprintf($lang["subscr_{$action}_error"], 6268881fcc9SAdrian Lang hsc($INFO['userinfo']['name']), 6278881fcc9SAdrian Lang prettyprint_id($target))); 6288881fcc9SAdrian Lang } 6298881fcc9SAdrian Lang msg(sprintf($lang["subscr_{$action}_success"], hsc($INFO['userinfo']['name']), 6308881fcc9SAdrian Lang prettyprint_id($target)), 1); 631cb3f9dbaSAdrian Lang act_redirect($ID, $act); 632cb3f9dbaSAdrian Lang 633cb3f9dbaSAdrian Lang // Assure that we have valid data if act_redirect somehow fails. 634cb3f9dbaSAdrian Lang $INFO['subscribed'] = get_info_subscribed(); 635cb3f9dbaSAdrian Lang return 'show'; 6368881fcc9SAdrian Lang} 6378881fcc9SAdrian Lang 6388881fcc9SAdrian Lang/** 6398881fcc9SAdrian Lang * Validate POST data 6408881fcc9SAdrian Lang * 6418881fcc9SAdrian Lang * Validates POST data for a subscribe or unsubscribe request. This is the 6428881fcc9SAdrian Lang * default action for the event ACTION_HANDLE_SUBSCRIBE. 6438881fcc9SAdrian Lang * 6448881fcc9SAdrian Lang * @author Adrian Lang <lang@cosmocode.de> 6458881fcc9SAdrian Lang */ 6467a9add1cSAdrian Langfunction subscription_handle_post(&$params) { 6478881fcc9SAdrian Lang global $INFO; 6488881fcc9SAdrian Lang global $lang; 6498881fcc9SAdrian Lang 6505b75cd1fSAdrian Lang // Get and validate parameters. 6518881fcc9SAdrian Lang if (!isset($params['target'])) { 65215741132SAndreas Gohr throw new Exception('no subscription target given'); 6535b75cd1fSAdrian Lang } 6548881fcc9SAdrian Lang $target = $params['target']; 6555b75cd1fSAdrian Lang $valid_styles = array('every', 'digest'); 6565b75cd1fSAdrian Lang if (substr($target, -1, 1) === ':') { 6575b75cd1fSAdrian Lang // Allow “list” subscribe style since the target is a namespace. 6585b75cd1fSAdrian Lang $valid_styles[] = 'list'; 6595b75cd1fSAdrian Lang } 6608881fcc9SAdrian Lang $style = valid_input_set('style', $valid_styles, $params, 66115741132SAndreas Gohr 'invalid subscription style given'); 6628881fcc9SAdrian Lang $action = valid_input_set('action', array('subscribe', 'unsubscribe'), 66315741132SAndreas Gohr $params, 'invalid subscription action given'); 664613964ecSGuy Brand 6655b75cd1fSAdrian Lang // Check other conditions. 6665b75cd1fSAdrian Lang if ($action === 'subscribe') { 6675b75cd1fSAdrian Lang if ($INFO['userinfo']['mail'] === '') { 6685b75cd1fSAdrian Lang throw new Exception($lang['subscr_subscribe_noaddress']); 66952b0dd67SGuy Brand } 6705b75cd1fSAdrian Lang } elseif ($action === 'unsubscribe') { 6715b75cd1fSAdrian Lang $is = false; 6725b75cd1fSAdrian Lang foreach($INFO['subscribed'] as $subscr) { 6735b75cd1fSAdrian Lang if ($subscr['target'] === $target) { 6745b75cd1fSAdrian Lang $is = true; 67552b0dd67SGuy Brand } 67652b0dd67SGuy Brand } 6775b75cd1fSAdrian Lang if ($is === false) { 67815741132SAndreas Gohr throw new Exception(sprintf($lang['subscr_not_subscribed'], 67915741132SAndreas Gohr $_SERVER['REMOTE_USER'], 6805b75cd1fSAdrian Lang prettyprint_id($target))); 6815b75cd1fSAdrian Lang } 6825b75cd1fSAdrian Lang // subscription_set deletes a subscription if style = null. 6835b75cd1fSAdrian Lang $style = null; 68452b0dd67SGuy Brand } 68552b0dd67SGuy Brand 6868881fcc9SAdrian Lang $data = in_array($style, array('list', 'digest')) ? time() : null; 6878881fcc9SAdrian Lang $params = compact('target', 'style', 'data', 'action'); 68852b0dd67SGuy Brand} 68952b0dd67SGuy Brand 690340756e4Sandi//Setup VIM: ex: et ts=2 enc=utf-8 : 691