17d101cc1SGerry Weißbach<?php 27d101cc1SGerry Weißbach 37d101cc1SGerry Weißbachif (!defined('DOKU_PLUGIN')) die('meh'); 47d101cc1SGerry Weißbachrequire_once(DOKU_PLUGIN . 'siteexport/inc/settings.php'); 57d101cc1SGerry Weißbachrequire_once(DOKU_PLUGIN . 'siteexport/inc/debug.php'); 67d101cc1SGerry Weißbach 77d101cc1SGerry Weißbachclass siteexport_functions extends DokuWiki_Plugin 87d101cc1SGerry Weißbach{ 97d101cc1SGerry Weißbach public $debug = null; 107d101cc1SGerry Weißbach public $settings = null; 117d101cc1SGerry Weißbach 12b324a190SMichael Hamann public function __construct($init = true, $isAJAX = false) 137d101cc1SGerry Weißbach { 147d101cc1SGerry Weißbach if ($init) 157d101cc1SGerry Weißbach { 167d101cc1SGerry Weißbach $this->debug = new siteexport_debug(); 172270cdc5SGerry Weißbach $this->debug->isAJAX = $isAJAX; 182270cdc5SGerry Weißbach 197d101cc1SGerry Weißbach $this->settings = new settings_plugin_siteexport_settings($this); 207d101cc1SGerry Weißbach $this->debug->message("Settings completed: zipFile", $this->settings->zipFile, 1); 217d101cc1SGerry Weißbach } 227d101cc1SGerry Weißbach } 237d101cc1SGerry Weißbach 247d101cc1SGerry Weißbach public function getPluginName() 257d101cc1SGerry Weißbach { 267d101cc1SGerry Weißbach return 'siteexport'; 277d101cc1SGerry Weißbach } 287d101cc1SGerry Weißbach 297d101cc1SGerry Weißbach public function downloadURL() 307d101cc1SGerry Weißbach { 316792d0cfSGerry Weißbach $params = array('cache' => 'nocache', 'siteexport' => $this->settings->pattern); 326792d0cfSGerry Weißbach 336792d0cfSGerry Weißbach if ($this->debug->debugLevel() < 5) { 346792d0cfSGerry Weißbach // If debug, then debug! 356792d0cfSGerry Weißbach $params['debug'] = $this->debug->debugLevel(); 366792d0cfSGerry Weißbach } 376792d0cfSGerry Weißbach 386792d0cfSGerry Weißbach return ml($this->settings->origZipFile, $params, true, '&'); 397d101cc1SGerry Weißbach } 407d101cc1SGerry Weißbach 417d101cc1SGerry Weißbach public function checkIfCacheFileExistsForFileWithPattern($file, $pattern) 427d101cc1SGerry Weißbach { 437d101cc1SGerry Weißbach if (!@file_exists($file)) 447d101cc1SGerry Weißbach { 457d101cc1SGerry Weißbach // If the cache File does not exist, move the newly created one over ... 466792d0cfSGerry Weißbach $this->debug->message("'{$file}' does not exist. Checking original ZipFile", null, 3); 477d101cc1SGerry Weißbach $newCacheFile = mediaFN($this->getSpecialExportFileName($this->settings->origZipFile, $pattern)); 487d101cc1SGerry Weißbach 497d101cc1SGerry Weißbach if (!@file_exists($newCacheFile)) 507d101cc1SGerry Weißbach { 517d101cc1SGerry Weißbach $this->debug->message("The export must have gone wrong. The cached file does not exist.", array("pattern" => $pattern, "original File" => $this->settings->origZipFile, "expected cached file" => $newCacheFile), 3); 527d101cc1SGerry Weißbach } 537d101cc1SGerry Weißbach 547d101cc1SGerry Weißbach $status = io_rename($newCacheFile, $file); 557d101cc1SGerry Weißbach $this->debug->message("had to move another original file over. Did it work? " . ($status ? 'Yes, it did.' : 'No, it did not.'), null, 2); 566792d0cfSGerry Weißbach } else { 576792d0cfSGerry Weißbach $this->debug->message("The file does exist!", $file, 2); 587d101cc1SGerry Weißbach } 597d101cc1SGerry Weißbach } 607d101cc1SGerry Weißbach 617d101cc1SGerry Weißbach 627d101cc1SGerry Weißbach /** 637d101cc1SGerry Weißbach * Returns an utf8 encoded Namespace for a Page and input Namespace 647d101cc1SGerry Weißbach * @param $NS 657d101cc1SGerry Weißbach * @param $PAGE 667d101cc1SGerry Weißbach */ 677d101cc1SGerry Weißbach function getNamespaceFromID($NS, &$PAGE) { 687d101cc1SGerry Weißbach global $conf; 697d101cc1SGerry Weißbach // Check current page - if its an NS add the startpage 707d101cc1SGerry Weißbach $clean = true; 717d101cc1SGerry Weißbach resolve_pageid(getNS($NS), $NS, $clean); 723aa0ad13SGerry Weißbach $NSa = explode(':', $NS); 733aa0ad13SGerry Weißbach if (!page_exists($NS) && array_pop($NSa) != strtolower($conf['start'])) { // Compare to lowercase since clean lowers it. 747d101cc1SGerry Weißbach $NS .= ':' . $conf['start']; 757d101cc1SGerry Weißbach resolve_pageid(getNS($NS), $NS, $clean); 767d101cc1SGerry Weißbach } 777d101cc1SGerry Weißbach 787d101cc1SGerry Weißbach $PAGE = noNS($NS); 797d101cc1SGerry Weißbach $NS = getNS($NS); 807d101cc1SGerry Weißbach 817d101cc1SGerry Weißbach return utf8_encodeFN(str_replace(':', '/', $NS)); 827d101cc1SGerry Weißbach } 837d101cc1SGerry Weißbach 847d101cc1SGerry Weißbach /** 857d101cc1SGerry Weißbach * create a file name for the page 867d101cc1SGerry Weißbach **/ 877d101cc1SGerry Weißbach public function getSiteName($ID, $overrideRewrite = false) { 887d101cc1SGerry Weißbach global $conf; 897d101cc1SGerry Weißbach 907d101cc1SGerry Weißbach if (empty($ID)) return false; 917d101cc1SGerry Weißbach 924c9a39daSGerry Weißbach // Remove extensions 934c9a39daSGerry Weißbach if ($overrideRewrite) { 94c6d15ed9SGerry Weißbach $ID = preg_replace("#\.(php|html)$#", '', $ID); 954c9a39daSGerry Weißbach } 964c9a39daSGerry Weißbach 977d101cc1SGerry Weißbach $url = $this->wl($this->cleanID($ID), null, true, null, null, $overrideRewrite); // this must be done with rewriting set to override 987d101cc1SGerry Weißbach //$url = $this->wl($this->cleanID($ID), null, true); // this must be done with rewriting set to override 997d101cc1SGerry Weißbach $uri = @parse_url($url); 1007d101cc1SGerry Weißbach if ($uri['path'][0] == '/') { 1017d101cc1SGerry Weißbach $uri['path'] = substr($uri['path'], 1); 1027d101cc1SGerry Weißbach } 1037d101cc1SGerry Weißbach 1047d101cc1SGerry Weißbach return $this->shortenName($uri['path'] . '.' . $this->settings->fileType); 1057d101cc1SGerry Weißbach } 1067d101cc1SGerry Weißbach 1077d101cc1SGerry Weißbach /** 1087d101cc1SGerry Weißbach * get the Title for the page 1097d101cc1SGerry Weißbach **/ 1107d101cc1SGerry Weißbach public function getSiteTitle($ID) { 1117d101cc1SGerry Weißbach if (useHeading('content') && $ID) { 1127d101cc1SGerry Weißbach $heading = p_get_first_heading($ID, true); 1137d101cc1SGerry Weißbach if ($heading) { 1147d101cc1SGerry Weißbach return $this->xmlEntities($heading); 1157d101cc1SGerry Weißbach } 1167d101cc1SGerry Weißbach } 117bca58ac1SGerry Weißbach $elements = explode(':', $ID); 118bca58ac1SGerry Weißbach return ucwords($this->xmlEntities(array_pop($elements))); 1197d101cc1SGerry Weißbach } 1207d101cc1SGerry Weißbach 1217d101cc1SGerry Weißbach /** 1227d101cc1SGerry Weißbach * Encoding ()taken from DW - but without needing the renderer 1237d101cc1SGerry Weißbach **/ 1247d101cc1SGerry Weißbach public function xmlEntities($string) { 1257d101cc1SGerry Weißbach return htmlspecialchars($string, ENT_QUOTES, 'UTF-8'); 1267d101cc1SGerry Weißbach } 1277d101cc1SGerry Weißbach 1287d101cc1SGerry Weißbach /** 1297d101cc1SGerry Weißbach * Create name for the file inside the zip and the replacements 1307d101cc1SGerry Weißbach **/ 1317d101cc1SGerry Weißbach function shortenName($NAME) 1327d101cc1SGerry Weißbach { 1337d101cc1SGerry Weißbach $NS = $this->settings->exportNamespace; 134774a858aSGerry Weißbach $NAME = preg_replace("%^" . preg_quote(DOKU_BASE, '%') . "%", "", $NAME); 135774a858aSGerry Weißbach $NAME = preg_replace("%^((_media|_detail)/)?(" . preg_quote($NS, '%') . "/)?%", "", $NAME); 1367d101cc1SGerry Weißbach 1371701f03cSGerry Weißbach if (strstr($NAME, '%')) { $NAME = rawurldecode($NAME); } 1381701f03cSGerry Weißbach 1397d101cc1SGerry Weißbach $this->debug->message("Shortening file to '$NAME'", null, 1); 1407d101cc1SGerry Weißbach return $NAME; 1417d101cc1SGerry Weißbach } 1427d101cc1SGerry Weißbach 1437d101cc1SGerry Weißbach /** 1447d101cc1SGerry Weißbach * Remove unwanted chars from ID 1457d101cc1SGerry Weißbach * 1467d101cc1SGerry Weißbach * Cleans a given ID to only use allowed characters. Accented characters are 1477d101cc1SGerry Weißbach * converted to unaccented ones 1487d101cc1SGerry Weißbach * 1497d101cc1SGerry Weißbach * @author Andreas Gohr <andi@splitbrain.org> 1507d101cc1SGerry Weißbach * @param string $raw_id The pageid to clean 1517d101cc1SGerry Weißbach * @param boolean $ascii Force ASCII 1527d101cc1SGerry Weißbach * @param boolean $media Allow leading or trailing _ for media files 1537d101cc1SGerry Weißbach */ 1547d101cc1SGerry Weißbach function cleanID($raw_id, $ascii = false, $media = false) { 1557d101cc1SGerry Weißbach global $conf; 1567d101cc1SGerry Weißbach global $lang; 1577d101cc1SGerry Weißbach static $sepcharpat = null; 1587d101cc1SGerry Weißbach 1597d101cc1SGerry Weißbach global $cache_cleanid; 1607d101cc1SGerry Weißbach $cache = & $cache_cleanid; 1617d101cc1SGerry Weißbach 1627d101cc1SGerry Weißbach // check if it's already in the memory cache 1637d101cc1SGerry Weißbach if (isset($cache[(string) $raw_id])) { 1647d101cc1SGerry Weißbach return $cache[(string) $raw_id]; 1657d101cc1SGerry Weißbach } 1667d101cc1SGerry Weißbach 1677d101cc1SGerry Weißbach $sepchar = $conf['sepchar']; 1687d101cc1SGerry Weißbach if ($sepcharpat == null) // build string only once to save clock cycles 1697d101cc1SGerry Weißbach $sepcharpat = '#\\' . $sepchar . '+#'; 1707d101cc1SGerry Weißbach 1717d101cc1SGerry Weißbach $id = trim((string) $raw_id); 1727d101cc1SGerry Weißbach // $id = utf8_strtolower($id); // NO LowerCase for us! 1737d101cc1SGerry Weißbach 1747d101cc1SGerry Weißbach //alternative namespace seperator 1757d101cc1SGerry Weißbach $id = strtr($id, ';', ':'); 1767d101cc1SGerry Weißbach if ($conf['useslash']) { 1777d101cc1SGerry Weißbach $id = strtr($id, '/', ':'); 1787d101cc1SGerry Weißbach } else { 1797d101cc1SGerry Weißbach $id = strtr($id, '/', $sepchar); 1807d101cc1SGerry Weißbach } 1817d101cc1SGerry Weißbach 1827d101cc1SGerry Weißbach if ($conf['deaccent'] == 2 || $ascii) $id = utf8_romanize($id); 1837d101cc1SGerry Weißbach if ($conf['deaccent'] || $ascii) $id = utf8_deaccent($id, -1); 1847d101cc1SGerry Weißbach 1855a843d1fSGerry Weißbach // We want spaces to be preserved when they are in the link. 1865a843d1fSGerry Weißbach global $UTF8_SPECIAL_CHARS2; 1875a843d1fSGerry Weißbach $UTF8_SPECIAL_CHARS2_SAVE = (string) $UTF8_SPECIAL_CHARS2; 1885a843d1fSGerry Weißbach $UTF8_SPECIAL_CHARS2 = str_replace(' ', '', $UTF8_SPECIAL_CHARS2); 1895a843d1fSGerry Weißbach 1907d101cc1SGerry Weißbach //remove specials 1917d101cc1SGerry Weißbach $id = utf8_stripspecials($id, $sepchar, '\*'); 1925a843d1fSGerry Weißbach $UTF8_SPECIAL_CHARS2 = $UTF8_SPECIAL_CHARS2_SAVE; 1937d101cc1SGerry Weißbach 1947d101cc1SGerry Weißbach if ($ascii) $id = utf8_strip($id); 1957d101cc1SGerry Weißbach 1967d101cc1SGerry Weißbach //clean up 1977d101cc1SGerry Weißbach $id = preg_replace($sepcharpat, $sepchar, $id); 1987d101cc1SGerry Weißbach $id = preg_replace('#:+#', ':', $id); 1997d101cc1SGerry Weißbach $id = ($media ? trim($id, ':.-') : trim($id, ':._-')); 2007d101cc1SGerry Weißbach $id = preg_replace('#:[:\._\-]+#', ':', $id); 2017d101cc1SGerry Weißbach 2027d101cc1SGerry Weißbach $cache[(string) $raw_id] = $id; 2037d101cc1SGerry Weißbach return($id); 2047d101cc1SGerry Weißbach } 2057d101cc1SGerry Weißbach 2067d101cc1SGerry Weißbach 2077d101cc1SGerry Weißbach /** 2087d101cc1SGerry Weißbach * This builds a link to a wikipage - changed for internal use here 2097d101cc1SGerry Weißbach * 2107d101cc1SGerry Weißbach * It handles URL rewriting and adds additional parameter if 2117d101cc1SGerry Weißbach * given in $more 2127d101cc1SGerry Weißbach * 2137d101cc1SGerry Weißbach * @author Andreas Gohr <andi@splitbrain.org> 2147d101cc1SGerry Weißbach */ 2157d101cc1SGerry Weißbach 2167d101cc1SGerry Weißbach function wl($id='',$more='',$abs=false,$sep='&', $IDexists=true, $overrideRewrite=false, $hadBase=false){ 2177d101cc1SGerry Weißbach global $conf; 2187d101cc1SGerry Weißbach 2191d20b534SGerry Weißbach $this->debug->message("Starting to build WL-URL for '$id'", $more, 1); 2207d101cc1SGerry Weißbach 2217d101cc1SGerry Weißbach if(is_array($more)){ 2221d20b534SGerry Weißbach 2231d20b534SGerry Weißbach $intermediateMore = ''; 2241d20b534SGerry Weißbach foreach( $more as $key => $value) { 2251d20b534SGerry Weißbach 2261d20b534SGerry Weißbach if ( strlen($intermediateMore) > 0 ) { 2271d20b534SGerry Weißbach $intermediateMore .= $sep; 2281d20b534SGerry Weißbach } 2291d20b534SGerry Weißbach 2301d20b534SGerry Weißbach if ( !is_array($value) ) { 2311d20b534SGerry Weißbach $intermediateMore .= rawurlencode($key) . '='; 2321d20b534SGerry Weißbach $intermediateMore .= rawurlencode($value); 2331d20b534SGerry Weißbach continue; 2341d20b534SGerry Weißbach } 2351d20b534SGerry Weißbach 2361d20b534SGerry Weißbach foreach( $value as $val ) { 2371d20b534SGerry Weißbach if ( strlen($intermediateMore) > 0 ) { 2381d20b534SGerry Weißbach $intermediateMore .= $sep; 2391d20b534SGerry Weißbach } 2401d20b534SGerry Weißbach 2411d20b534SGerry Weißbach $intermediateMore .= rawurlencode($key) . '[]='; 2421d20b534SGerry Weißbach $intermediateMore .= rawurlencode($val); 2431d20b534SGerry Weißbach } 2441d20b534SGerry Weißbach } 2451d20b534SGerry Weißbach 2461d20b534SGerry Weißbach $more = $intermediateMore; 2477d101cc1SGerry Weißbach } else { 2487d101cc1SGerry Weißbach $more = str_replace(',', $sep, $more); 2497d101cc1SGerry Weißbach } 2507d101cc1SGerry Weißbach 2517d101cc1SGerry Weißbach $id = idfilter($id); 2527d101cc1SGerry Weißbach 2537d101cc1SGerry Weißbach if ($abs) { 2547d101cc1SGerry Weißbach $xlink = DOKU_URL; 2557d101cc1SGerry Weißbach if (!$IDexists && !$hadBase) { // If the file does not exist, we have to remove the base. This link my be one to an parallel BASE. 2567d101cc1SGerry Weißbach $xlink = preg_replace('#' . DOKU_BASE . '$#', '', $xlink); 2577d101cc1SGerry Weißbach } 2587d101cc1SGerry Weißbach } else if ($IDexists || $hadBase) { // if the ID does exist, we may add the base. 2597d101cc1SGerry Weißbach $xlink = DOKU_BASE; 2607d101cc1SGerry Weißbach } else { 2617d101cc1SGerry Weißbach $xlink = ""; 2627d101cc1SGerry Weißbach } 2637d101cc1SGerry Weißbach 2647d101cc1SGerry Weißbach // $this->debug->message("internal WL function Before Replacing: '$xlink'", array(DOKU_REL, DOKU_URL, DOKU_BASE, $xlink), 2); 2657d101cc1SGerry Weißbach $xlink = preg_replace('#(?<!http:|https:)//+#', '/', ($abs ? '' : '/') . "$xlink/"); // ensure slashes at beginning and ending, but strip doubles 2667d101cc1SGerry Weißbach $this->debug->message("'$xlink'", array(DOKU_REL, DOKU_URL, DOKU_BASE, $xlink), 2); 2677d101cc1SGerry Weißbach 2687d101cc1SGerry Weißbach if ($overrideRewrite) { 2697d101cc1SGerry Weißbach $this->debug->message("Override enabled.", null, 1); 2707d101cc1SGerry Weißbach $id = strtr($id, ':', '/'); 2717d101cc1SGerry Weißbach 2727d101cc1SGerry Weißbach $xlink .= $id; 2737d101cc1SGerry Weißbach if ($more) $xlink .= '?' . $more; 2747d101cc1SGerry Weißbach } else { 2757d101cc1SGerry Weißbach if ($conf['userewrite'] == 2) { 2767d101cc1SGerry Weißbach $xlink .= DOKU_SCRIPT . '/' . $id; 2777d101cc1SGerry Weißbach if ($more) $xlink .= '?' . $more; 2787d101cc1SGerry Weißbach }elseif ($conf['userewrite']) { 2797d101cc1SGerry Weißbach $xlink .= $id; 2807d101cc1SGerry Weißbach if ($more) $xlink .= '?' . $more; 2817d101cc1SGerry Weißbach }elseif ($id) { 2827d101cc1SGerry Weißbach $xlink .= DOKU_SCRIPT . '?id=' . $id; 2837d101cc1SGerry Weißbach if ($more) $xlink .= $sep . $more; 2847d101cc1SGerry Weißbach } else { 2857d101cc1SGerry Weißbach $xlink .= DOKU_SCRIPT; 2867d101cc1SGerry Weißbach if ($more) $xlink .= '?' . $more; 2877d101cc1SGerry Weißbach } 2887d101cc1SGerry Weißbach } 2897d101cc1SGerry Weißbach 2907d101cc1SGerry Weißbach $this->debug->message("internal WL function result: '$xlink'", null, 2); 2917d101cc1SGerry Weißbach 2927d101cc1SGerry Weißbach return $xlink; 2937d101cc1SGerry Weißbach } 2947d101cc1SGerry Weißbach 2957d101cc1SGerry Weißbach /** 2967d101cc1SGerry Weißbach * Create the export file name - this is the file where everything is being stored 2977d101cc1SGerry Weißbach * @param $FILE 2987d101cc1SGerry Weißbach * @param $PATTERN - additional pattern for re-using old files 2997d101cc1SGerry Weißbach */ 3007d101cc1SGerry Weißbach public function getSpecialExportFileName($FILE, $PATTERN = null) { 3017d101cc1SGerry Weißbach 3027d101cc1SGerry Weißbach if (empty($FILE)) 3037d101cc1SGerry Weißbach { 3047d101cc1SGerry Weißbach $FILE = $this->settings->origZipFile; 3057d101cc1SGerry Weißbach } 3067d101cc1SGerry Weißbach 3077d101cc1SGerry Weißbach if (empty($PATTERN) && empty($this->settings->pattern)) { 3086792d0cfSGerry Weißbach $this->debug->message("Generating an internal md5 pattern. This will go wrong - and won't cache properly.", null, 3); 3097d101cc1SGerry Weißbach $PATTERN = md5(microtime(false)); 3107d101cc1SGerry Weißbach } 3117d101cc1SGerry Weißbach 3127d101cc1SGerry Weißbach // Set Pattern Global for other stuff 3137d101cc1SGerry Weißbach if (empty($this->settings->pattern)) { 31482618ac8SGerry Weißbach $this->settings['pattern'] = $PATTERN; 3157d101cc1SGerry Weißbach } else { 3167d101cc1SGerry Weißbach $PATTERN = $this->settings->pattern; 3177d101cc1SGerry Weißbach } 3187d101cc1SGerry Weißbach 3197d101cc1SGerry Weißbach $FA = explode('.', $FILE); 3207d101cc1SGerry Weißbach $EXT = array_pop($FA); 3217d101cc1SGerry Weißbach array_push($FA, 'auto'); 3227d101cc1SGerry Weißbach array_push($FA, $PATTERN); 3237d101cc1SGerry Weißbach array_push($FA, $EXT); 3247d101cc1SGerry Weißbach 3257d101cc1SGerry Weißbach $fileName = implode('.', $FA); 3267d101cc1SGerry Weißbach $this->debug->message("Export Filename for '$FILE' will be: '$fileName'", null, 2); 3277d101cc1SGerry Weißbach return $fileName; 3287d101cc1SGerry Weißbach } 3297d101cc1SGerry Weißbach 3307d101cc1SGerry Weißbach public function getCacheFileNameForPattern($PATTERN = null) 3317d101cc1SGerry Weißbach { 3327d101cc1SGerry Weißbach if ($PATTERN == null) { 3337d101cc1SGerry Weißbach $PATTERN = $this->settings->pattern; 3347d101cc1SGerry Weißbach } 3357d101cc1SGerry Weißbach 3367d101cc1SGerry Weißbach return getCacheName($this->getSpecialExportFileName($this->settings->origZipFile, $PATTERN), '.' . basename(mediaFN($this->settings->origZipFile))); 3377d101cc1SGerry Weißbach } 3387d101cc1SGerry Weißbach 3390571ece2SScrutinizer Auto-Fixer /** 3400571ece2SScrutinizer Auto-Fixer * @param integer $counter 3410571ece2SScrutinizer Auto-Fixer */ 3427d101cc1SGerry Weißbach function startRedirctProcess($counter) { 3437d101cc1SGerry Weißbach global $ID; 3447d101cc1SGerry Weißbach 3457d101cc1SGerry Weißbach $URL = wl($ID); 3467d101cc1SGerry Weißbach 3477d101cc1SGerry Weißbach $additionalParameters = $_REQUEST; 3487d101cc1SGerry Weißbach $additionalParameters['startcounter'] = $counter; 3497d101cc1SGerry Weißbach $additionalParameters['pattern'] = $this->settings->pattern; 3507d101cc1SGerry Weißbach 3517d101cc1SGerry Weißbach unset($additionalParameters['id']); 3527d101cc1SGerry Weißbach unset($additionalParameters['u']); 3537d101cc1SGerry Weißbach unset($additionalParameters['p']); 3547d101cc1SGerry Weißbach unset($additionalParameters['r']); 3557d101cc1SGerry Weißbach unset($additionalParameters['http_credentials']); 3567d101cc1SGerry Weißbach 3577d101cc1SGerry Weißbach $this->addAdditionalParametersToURL($URL, $additionalParameters); 3587d101cc1SGerry Weißbach $this->debug->message("Redirecting to '$URL'", null, 2); 3597d101cc1SGerry Weißbach 3607d101cc1SGerry Weißbach send_redirect($URL); 3617d101cc1SGerry Weißbach exit(0); // Should not be reached, but anyways 3627d101cc1SGerry Weißbach } 3637d101cc1SGerry Weißbach 3647d101cc1SGerry Weißbach /** 3657d101cc1SGerry Weißbach * Builds additional Parameters into the URL given 3667d101cc1SGerry Weißbach * @param $URL 3677d101cc1SGerry Weißbach * @param $newAdditionalParameters 3687d101cc1SGerry Weißbach */ 3697d101cc1SGerry Weißbach function addAdditionalParametersToURL(&$URL, $newAdditionalParameters) { 3707d101cc1SGerry Weißbach 3717d101cc1SGerry Weißbach // Add additionalParameters 3727d101cc1SGerry Weißbach if (!empty($newAdditionalParameters)) { 3737d101cc1SGerry Weißbach foreach ($newAdditionalParameters as $key => $value) { 3747d101cc1SGerry Weißbach if (empty($key) || empty($value)) { continue; } 3757d101cc1SGerry Weißbach 3767d101cc1SGerry Weißbach $append = ''; 3777d101cc1SGerry Weißbach 3787d101cc1SGerry Weißbach if (is_array($value)) { 3797d101cc1SGerry Weißbach foreach (array_values($value) as $aValue) { // Array Handling 3807d101cc1SGerry Weißbach $URL .= (strstr($URL, '?') ? '&' : '?') . $key . "[]=$aValue"; 3817d101cc1SGerry Weißbach } 3827d101cc1SGerry Weißbach } else { 3837d101cc1SGerry Weißbach $append = "$key=$value"; 3847d101cc1SGerry Weißbach $URL .= empty($append) || strstr($URL, $append) ? '' : (strstr($URL, '?') ? '&' : '?') . $append; 3857d101cc1SGerry Weißbach } 3867d101cc1SGerry Weißbach 3877d101cc1SGerry Weißbach } 3887d101cc1SGerry Weißbach } 3897d101cc1SGerry Weißbach } 3907d101cc1SGerry Weißbach 3917d101cc1SGerry Weißbach /** 3927d101cc1SGerry Weißbach * Cleans the wiki variables and returns a rebuild URL that has the new variables at hand 3937d101cc1SGerry Weißbach * @param $data 3947d101cc1SGerry Weißbach */ 3957d101cc1SGerry Weißbach function prepare_POSTData($data) 3967d101cc1SGerry Weißbach { 3977d101cc1SGerry Weißbach $NS = !empty($data['ns']) ? $data['ns'] : $data['id']; 3987d101cc1SGerry Weißbach 3997d101cc1SGerry Weißbach $this->removeWikiVariables($data); 4007d101cc1SGerry Weißbach $data['do'] = 'siteexport'; 4017d101cc1SGerry Weißbach $additionalKeys = ''; 4027d101cc1SGerry Weißbach 4037d101cc1SGerry Weißbach ksort($data); 4047d101cc1SGerry Weißbach 4057d101cc1SGerry Weißbach $this->debug->message("Prepared POST data:", $data, 1); 4067d101cc1SGerry Weißbach 4077d101cc1SGerry Weißbach foreach ($data as $key => $value) { 4087d101cc1SGerry Weißbach 4097d101cc1SGerry Weißbach if (!is_array($value)) { continue; } 4107d101cc1SGerry Weißbach $this->debug->message("Found inner Array:", $value, 1); 4117d101cc1SGerry Weißbach 4127d101cc1SGerry Weißbach asort($value); 4137d101cc1SGerry Weißbach foreach ($value as $innerKey => $aValue) 4147d101cc1SGerry Weißbach { 4157d101cc1SGerry Weißbach if (is_numeric($innerKey)) 4167d101cc1SGerry Weißbach { 4177d101cc1SGerry Weißbach $innerKey = ''; 4187d101cc1SGerry Weißbach } 4197d101cc1SGerry Weißbach 4207d101cc1SGerry Weißbach $additionalKeys .= "&$key" . "[$innerKey]=$aValue"; 4217d101cc1SGerry Weißbach } 4227d101cc1SGerry Weißbach 4237d101cc1SGerry Weißbach unset($data[$key]); 4247d101cc1SGerry Weißbach } 4257d101cc1SGerry Weißbach 4267d101cc1SGerry Weißbach return wl($NS, $data, true, '&') . $additionalKeys; 4277d101cc1SGerry Weißbach } 4287d101cc1SGerry Weißbach 4297d101cc1SGerry Weißbach /** 4307d101cc1SGerry Weißbach * Parses a String into a $_REQUEST Like variant. You have to tell if a decode of the values is needed 4317d101cc1SGerry Weißbach * @param $inputArray 4327d101cc1SGerry Weißbach * @param $decode 4337d101cc1SGerry Weißbach */ 4347d101cc1SGerry Weißbach public function parseStringToRequestArray($inputArray, $decode=false) 4357d101cc1SGerry Weißbach { 4367d101cc1SGerry Weißbach global $plugin_controller; 4377d101cc1SGerry Weißbach 4387d101cc1SGerry Weißbach $outputArray = $inputArray; 4397d101cc1SGerry Weißbach if ( !is_array($inputArray) ) 4407d101cc1SGerry Weißbach { 4417d101cc1SGerry Weißbach $intermediate = str_replace("&", "&", $inputArray); 4427d101cc1SGerry Weißbach 4437d101cc1SGerry Weißbach $outputArray = array(); 4447d101cc1SGerry Weißbach foreach( explode("&", $intermediate) as $param ) { 4457d101cc1SGerry Weißbach list($key, $value) = explode("=", $param, 2); 4467d101cc1SGerry Weißbach 4477d101cc1SGerry Weißbach // This is needed if we do want to calculate $_REQUEST for a non HTTP-Request 4487d101cc1SGerry Weißbach if ( $decode) 4497d101cc1SGerry Weißbach { 4507d101cc1SGerry Weißbach $value = urldecode($value); 4517d101cc1SGerry Weißbach } 4527d101cc1SGerry Weißbach 4537d101cc1SGerry Weißbach if ( empty($key) ) { continue; } // Don't check on Value, because there may be only the key that should be preserved 4547d101cc1SGerry Weißbach 4557d101cc1SGerry Weißbach if ( substr($key, -2) == '[]' ) { 4567d101cc1SGerry Weißbach $key = substr($key, 0, -2); 4577d101cc1SGerry Weißbach if ( !is_array($outputArray[$key]) ) { 4587d101cc1SGerry Weißbach $outputArray[$key] = array(); 4597d101cc1SGerry Weißbach } 4607d101cc1SGerry Weißbach 4617d101cc1SGerry Weißbach array_push($outputArray[$key], $value); // Array Handling 4627d101cc1SGerry Weißbach } else { 4637d101cc1SGerry Weißbach $outputArray[$key] = $value; 4647d101cc1SGerry Weißbach } 4657d101cc1SGerry Weißbach } 4667d101cc1SGerry Weißbach } 4677d101cc1SGerry Weißbach 4687d101cc1SGerry Weißbach if (!empty($outputArray['diPlu'])) { 4697d101cc1SGerry Weißbach 4707d101cc1SGerry Weißbach $allPlugins = array(); 4717d101cc1SGerry Weißbach foreach ($plugin_controller->getList(null, true) as $plugin) { 4727d101cc1SGerry Weißbach // check for CSS or JS 4737d101cc1SGerry Weißbach if (!file_exists(DOKU_PLUGIN . "$plugin/script.js") && !file_exists(DOKU_PLUGIN . "$p/style.css")) { continue; } 4747d101cc1SGerry Weißbach $allPlugins[] = $plugin; 4757d101cc1SGerry Weißbach } 4767d101cc1SGerry Weißbach 4777d101cc1SGerry Weißbach if (count($outputArray['diPlu']) > (count($allPlugins)/2)) { 4787d101cc1SGerry Weißbach $outputArray['diInv'] = 1; 4797d101cc1SGerry Weißbach $outputArray['diPlu'] = array_diff($allPlugins, $outputArray['diPlu']); 4807d101cc1SGerry Weißbach } 4817d101cc1SGerry Weißbach } 4827d101cc1SGerry Weißbach 4837d101cc1SGerry Weißbach return $outputArray; 4847d101cc1SGerry Weißbach } 4857d101cc1SGerry Weißbach 4867d101cc1SGerry Weißbach /** 4877d101cc1SGerry Weißbach * Remove certain fields from the list. 4887d101cc1SGerry Weißbach * @param $removeArray 4897d101cc1SGerry Weißbach * @param $advanced 4907d101cc1SGerry Weißbach * @param $isString 4917d101cc1SGerry Weißbach */ 4927d101cc1SGerry Weißbach function removeWikiVariables(&$removeArray, $advanced = false, $isString = false) { 4937d101cc1SGerry Weißbach 4947d101cc1SGerry Weißbach $removeArray = $this->parseStringToRequestArray($removeArray); 4957d101cc1SGerry Weißbach 4967d101cc1SGerry Weißbach // 2010-08-23 - If there is still the media set, retain the id for e.g. detail.php 4977d101cc1SGerry Weißbach if (!isset($removeArray['media'])) { 4987d101cc1SGerry Weißbach unset($removeArray['id']); 4997d101cc1SGerry Weißbach } 5007d101cc1SGerry Weißbach 5017d101cc1SGerry Weißbach unset($removeArray['do']); 5027d101cc1SGerry Weißbach unset($removeArray['ns']); 5037d101cc1SGerry Weißbach unset($removeArray['call']); 5047d101cc1SGerry Weißbach unset($removeArray['sectok']); 5057d101cc1SGerry Weißbach unset($removeArray['rndval']); 5067d101cc1SGerry Weißbach unset($removeArray['tseed']); 5077d101cc1SGerry Weißbach unset($removeArray['http_credentials']); 5087d101cc1SGerry Weißbach unset($removeArray['u']); 5097d101cc1SGerry Weißbach unset($removeArray['p']); 5107d101cc1SGerry Weißbach unset($removeArray['r']); 5117d101cc1SGerry Weißbach unset($removeArray['base']); 5127d101cc1SGerry Weißbach unset($removeArray['siteexport']); 5137d101cc1SGerry Weißbach unset($removeArray['DokuWiki']); 5147d101cc1SGerry Weißbach 5157d101cc1SGerry Weißbach if ($removeArray['renderer'] == 'xhtml') { 5167d101cc1SGerry Weißbach $removeArray['do'] = 'export_' . $removeArray['renderer']; 5177d101cc1SGerry Weißbach unset($removeArray['renderer']); 5187d101cc1SGerry Weißbach } 5197d101cc1SGerry Weißbach 5202270cdc5SGerry Weißbach // Keep custom options 5212270cdc5SGerry Weißbach if (is_array($removeArray['customoptionname']) && is_array($removeArray['customoptionvalue']) && count($removeArray['customoptionname']) == count($removeArray['customoptionvalue'])) 5222270cdc5SGerry Weißbach { 5232270cdc5SGerry Weißbach for ($index = 0; $index < count($removeArray['customoptionname']); $index++) 5242270cdc5SGerry Weißbach { 5252270cdc5SGerry Weißbach $removeArray[$removeArray['customoptionname'][$index]] = $removeArray['customoptionvalue'][$index]; 5262270cdc5SGerry Weißbach } 5272270cdc5SGerry Weißbach unset($removeArray['customoptionname']); 5282270cdc5SGerry Weißbach unset($removeArray['customoptionvalue']); 5292270cdc5SGerry Weißbach } 5302270cdc5SGerry Weißbach 5317d101cc1SGerry Weißbach if ($advanced) { 5327d101cc1SGerry Weißbach if ($removeArray['renderer'] != 'xhtml' && !empty($removeArray['renderer'])) { 5337d101cc1SGerry Weißbach $removeArray['do'] = 'export_' . $removeArray['renderer']; 5347d101cc1SGerry Weißbach } 5357d101cc1SGerry Weißbach 5367d101cc1SGerry Weißbach // 2010-08-25 - Need fakeMedia for some _detail cases with rewrite = 2 5377d101cc1SGerry Weißbach if (isset($removeArray['fakeMedia'])) { 5387d101cc1SGerry Weißbach unset($removeArray['media']); 5397d101cc1SGerry Weißbach unset($removeArray['fakeMedia']); 5407d101cc1SGerry Weißbach } 5417d101cc1SGerry Weißbach 5427d101cc1SGerry Weißbach /* remove internal params */ 5437d101cc1SGerry Weißbach unset($removeArray['ens']); 5447d101cc1SGerry Weißbach unset($removeArray['renderer']); 5457d101cc1SGerry Weißbach unset($removeArray['site']); 5467d101cc1SGerry Weißbach unset($removeArray['namespace']); 5477d101cc1SGerry Weißbach unset($removeArray['exportbody']); 5487d101cc1SGerry Weißbach unset($removeArray['addParams']); 5497d101cc1SGerry Weißbach unset($removeArray['template']); 5507d101cc1SGerry Weißbach unset($removeArray['eclipseDocZip']); 5517d101cc1SGerry Weißbach unset($removeArray['useTocFile']); 5527d101cc1SGerry Weißbach unset($removeArray['JavaHelpDocZip']); 5537d101cc1SGerry Weißbach unset($removeArray['depth']); 5547d101cc1SGerry Weißbach unset($removeArray['depthType']); 5557d101cc1SGerry Weißbach unset($removeArray['startcounter']); 5567d101cc1SGerry Weißbach unset($removeArray['pattern']); 5577d101cc1SGerry Weißbach unset($removeArray['TOCMapWithoutTranslation']); 5586792d0cfSGerry Weißbach // unset($removeArray['disableCache']); 55928601108SGerry Weißbach unset($removeArray['debug']); 5607d101cc1SGerry Weißbach } 5617d101cc1SGerry Weißbach 5627d101cc1SGerry Weißbach if ($isString && is_array($removeArray)) { 5637d101cc1SGerry Weißbach $intermediate = $removeArray; 5647d101cc1SGerry Weißbach $removeArray = array(); 5657d101cc1SGerry Weißbach 5667d101cc1SGerry Weißbach foreach ($intermediate as $key => $value) { 5677d101cc1SGerry Weißbach if (is_array($value)) { 5687d101cc1SGerry Weißbach foreach (array_values($value) as $aValue) { // Array Handling 5697d101cc1SGerry Weißbach $removeArray[] = $key . "[]=$aValue"; 5707d101cc1SGerry Weißbach } 5717d101cc1SGerry Weißbach } else { 5727d101cc1SGerry Weißbach $value = trim($value); 5737d101cc1SGerry Weißbach 5747d101cc1SGerry Weißbach $removeArray[] = "$key" . (((empty($value) && intval($value) !== 0)) || $value == '' ? '' : "=$value"); // If the Value is empty, the Key must be preserved 5757d101cc1SGerry Weißbach } 5767d101cc1SGerry Weißbach } 5777d101cc1SGerry Weißbach 5780b4abc9fSGerry Weißbach //$removeArray = implode( ($this->settings->fileType == 'pdf' ? "&" : "&"), $removeArray); 5790b4abc9fSGerry Weißbach $removeArray = implode("&", $removeArray); // The & made problems with the HTTPClient / Apache. It should not be a problem to have & 5807d101cc1SGerry Weißbach } 5817d101cc1SGerry Weißbach } 5827d101cc1SGerry Weißbach 5837d101cc1SGerry Weißbach /** 5847d101cc1SGerry Weißbach * returns a hashed name for the parameters 5857d101cc1SGerry Weißbach * @param $parameters 5867d101cc1SGerry Weißbach */ 587f44c759aSGerry Weißbach public function hashNameForParameters($parameters) 5887d101cc1SGerry Weißbach { 5897d101cc1SGerry Weißbach return md5($parameters); 5907d101cc1SGerry Weißbach } 5917d101cc1SGerry Weißbach 5927d101cc1SGerry Weißbach /** 5937d101cc1SGerry Weißbach * Takes an URL and transforms it into the path+query part 5947d101cc1SGerry Weißbach * Used several times, e.g. for genering the hash for the cache file 5950571ece2SScrutinizer Auto-Fixer * @param string $url 5967d101cc1SGerry Weißbach */ 5977d101cc1SGerry Weißbach public function urlToPathAndParams($url) 5987d101cc1SGerry Weißbach { 5997d101cc1SGerry Weißbach $query = parse_url($url, PHP_URL_QUERY); 6007d101cc1SGerry Weißbach $path = preg_replace(":^" . DOKU_REL . ":", "", parse_url($url, PHP_URL_PATH)); 6017d101cc1SGerry Weißbach return "{$path}?{$query}"; 6027d101cc1SGerry Weißbach } 6037d101cc1SGerry Weißbach 6047d101cc1SGerry Weißbach /** 6057d101cc1SGerry Weißbach * Transforms an $_REQUEST into a Hash that can be used for cron and cache file 6067d101cc1SGerry Weißbach * @param $request 6077d101cc1SGerry Weißbach */ 6087d101cc1SGerry Weißbach public function requestParametersToCacheHash($request) 6097d101cc1SGerry Weißbach { 6107d101cc1SGerry Weißbach $params = $this->urlToPathAndParams($this->prepare_POSTData($request)); 6117d101cc1SGerry Weißbach $this->debug->message("Calculated the following Cache Hash URL: ", $params, 2); 612f44c759aSGerry Weißbach return $this->hashNameForParameters($params); 6137d101cc1SGerry Weißbach } 6147d101cc1SGerry Weißbach 6157d101cc1SGerry Weißbach /** 6163aa0ad13SGerry Weißbach * Check a replaceURL against a baseURL - and make the replaceURL relative against it 6173aa0ad13SGerry Weißbach * @param replaceURL - URL which will be made relative if needed 6183aa0ad13SGerry Weißbach * @param baseURL - URL which is the reference to be made relative against 6190571ece2SScrutinizer Auto-Fixer * @param string $replaceURL 6207d101cc1SGerry Weißbach */ 6218a20a4b4SGerry Weißbach public function getRelativeURL($replaceURL, $baseURL, $existingPageID = null) 6227d101cc1SGerry Weißbach { 6233aa0ad13SGerry Weißbach // Base is always absolute without anything at the beginning 6243aa0ad13SGerry Weißbach if (preg_match("#^(\.\./)+#", $baseURL)) { 6253aa0ad13SGerry Weißbach $this->debug->message("The baseURL was not absolute.", $baseURL, 1); 6263aa0ad13SGerry Weißbach return $replaceURL; 6273aa0ad13SGerry Weißbach } 6287d101cc1SGerry Weißbach 6293aa0ad13SGerry Weißbach $origReplaceURL = $replaceURL; 6303aa0ad13SGerry Weißbach $replaceURL = preg_replace("#^(\.\./)+#", '', $replaceURL); 6317d101cc1SGerry Weißbach 6323aa0ad13SGerry Weißbach // Remove ../ at beginning to get the absolute path 6333aa0ad13SGerry Weißbach if ($replaceURL == $origReplaceURL) { 6343aa0ad13SGerry Weißbach $this->debug->message("The replaceURL was already absolute.", $replaceURL, 1); 6353aa0ad13SGerry Weißbach return $replaceURL; 6363aa0ad13SGerry Weißbach } 6377d101cc1SGerry Weißbach 6383aa0ad13SGerry Weißbach $replaceParts = explode('/', $replaceURL); 6393aa0ad13SGerry Weißbach $fileName = array_pop($replaceParts); // Get file 6407d101cc1SGerry Weißbach 6413aa0ad13SGerry Weißbach $baseParts = explode('/', $baseURL); 6423aa0ad13SGerry Weißbach array_pop($baseParts); // Remove file. We only need the path to this location. 6437d101cc1SGerry Weißbach 6443aa0ad13SGerry Weißbach $this->debug->message("State before kicking.", array($replaceParts, $baseParts), 1); 6453aa0ad13SGerry Weißbach 6463aa0ad13SGerry Weißbach // Kick all ../ 6478a20a4b4SGerry Weißbach $originalBasePartsCount = count($baseParts); 6483aa0ad13SGerry Weißbach while (count($replaceParts) > 0 && count($baseParts) > 0) { 6493aa0ad13SGerry Weißbach 6503aa0ad13SGerry Weißbach if ($baseParts[0] == $replaceParts[0]) { 6513aa0ad13SGerry Weißbach // Beginning is OK, so remove it. 6527d101cc1SGerry Weißbach array_shift($replaceParts); 6537d101cc1SGerry Weißbach array_shift($baseParts); 6543aa0ad13SGerry Weißbach } else { 6557d101cc1SGerry Weißbach break; 6567d101cc1SGerry Weißbach } 6573aa0ad13SGerry Weißbach 6587d101cc1SGerry Weißbach } 6597d101cc1SGerry Weißbach 6603aa0ad13SGerry Weißbach $this->debug->message("Found URL '{$replaceURL}' that is relative to current page '{$baseURL}'.", array($replaceParts, $baseParts), 1); 6617d101cc1SGerry Weißbach 6623aa0ad13SGerry Weißbach // Remove everything that is identical 6633aa0ad13SGerry Weißbach $replaceParts[] = $fileName; 6647d101cc1SGerry Weißbach 6658a20a4b4SGerry Weißbach // do the final link calculation 6668a20a4b4SGerry Weißbach $finalLink = str_repeat('../', count($baseParts)) . implode('/', $replaceParts); 6678a20a4b4SGerry Weißbach 6688a20a4b4SGerry Weißbach // find out if this is outside of our own export context, becond the baseURL 669de387d04SGerry Weißbach $offsiteTemplate = $this->getConf("offSiteLinkTemplate"); 670de387d04SGerry Weißbach if (count($baseParts) == $originalBasePartsCount && $existingPageID != null && !empty($offsiteTemplate)) { 6718a20a4b4SGerry Weißbach 672de387d04SGerry Weißbach $offsiteTemplate = str_replace('RAWID', $existingPageID, $offsiteTemplate); 6738a20a4b4SGerry Weißbach 6748a20a4b4SGerry Weißbach $check = null; 675de387d04SGerry Weißbach $offsiteTemplate = str_replace('CONTEXTID', array_pop($this->getMapID($existingPageID, null, $check)), $offsiteTemplate); 676de387d04SGerry Weißbach $offsiteTemplate = str_replace('LINK', $finalLink, $offsiteTemplate); 6778a20a4b4SGerry Weißbach 678de387d04SGerry Weißbach $finalLink = $$offsiteTemplate; 6798a20a4b4SGerry Weißbach } 6808a20a4b4SGerry Weißbach 6818a20a4b4SGerry Weißbach return $finalLink; 6828a20a4b4SGerry Weißbach } 6838a20a4b4SGerry Weißbach 6848a20a4b4SGerry Weißbach function mapIDWithAnchor(&$n, $key, $postfix) 6858a20a4b4SGerry Weißbach { 6868a20a4b4SGerry Weißbach if (empty($postfix)) return; 6878a20a4b4SGerry Weißbach $n .= '-' . $postfix; 6888a20a4b4SGerry Weißbach } 6898a20a4b4SGerry Weißbach 6908a20a4b4SGerry Weißbach function getMapID($elemID, $postfix, &$check) 6918a20a4b4SGerry Weißbach { 6928a20a4b4SGerry Weißbach $meta = p_get_metadata($elemID, 'context', true); 6938a20a4b4SGerry Weißbach 6948a20a4b4SGerry Weißbach if (empty($meta['id'])) { 695fbfbd79dSGerry Weißbach $title = empty($meta['title']) ? $this->getSiteTitle($elemID) : $meta['title']; 696fbfbd79dSGerry Weißbach $meta['id'] = sectionID($this->cleanId(strtolower($title)), $check); 6978a20a4b4SGerry Weißbach } 6988a20a4b4SGerry Weißbach 6998a20a4b4SGerry Weißbach $mapID = explode('|', $meta['id']); 7008a20a4b4SGerry Weißbach array_walk($mapID, array($this, 'mapIDWithAnchor'), $postfix); 7018a20a4b4SGerry Weißbach 7028a20a4b4SGerry Weißbach return $mapID; 7037d101cc1SGerry Weißbach } 704ec1dc739SGerry Weißbach 705ec1dc739SGerry Weißbach public function hasAuthentication() { 706ec1dc739SGerry Weißbach $user = $this->getConf('defaultAuthenticationUser'); 707ec1dc739SGerry Weißbach $password = $this->getConf('defaultAuthenticationPassword'); 708ec1dc739SGerry Weißbach return empty($user) ? false : array( 709ec1dc739SGerry Weißbach 'user' => $user, 710ec1dc739SGerry Weißbach 'password' => $password 711ec1dc739SGerry Weißbach ); 712ec1dc739SGerry Weißbach } 713ec1dc739SGerry Weißbach 714ec1dc739SGerry Weißbach public function authenticate() { 715ec1dc739SGerry Weißbach if (!isset($_SERVER['HTTP_AUTHORIZATION']) && $this->hasAuthentication()) { 7161e0bea35SGerry Weissbach $authentication = $this->hasAuthentication(); 7171e0bea35SGerry Weissbach $_SERVER['HTTP_AUTHORIZATION'] = 'Basic ' . base64_encode($authentication['user'] . ':' . $authentication['password']); 7181e0bea35SGerry Weissbach $this->debug->message("Re-authenticating with default user from configuration", $authentication['user'], 3); 7191e0bea35SGerry Weissbach return auth_setup(); 720ec1dc739SGerry Weißbach } 7211e0bea35SGerry Weissbach 7221e0bea35SGerry Weissbach return false; 723ec1dc739SGerry Weißbach } 724*a0417606SGerry Weißbach 725*a0417606SGerry Weißbach /** 726*a0417606SGerry Weißbach * Check the secret CSRF token, regardless of the current authorization 727*a0417606SGerry Weißbach * 728*a0417606SGerry Weißbach * @param null|string $token security token 729*a0417606SGerry Weißbach * @param null|boolean $softfail if a message is to be thrown. 730*a0417606SGerry Weißbach * @return bool success if the token matched 731*a0417606SGerry Weißbach */ 732*a0417606SGerry Weißbach function checkSecurityToken($token = null, $softfail = true) { 733*a0417606SGerry Weißbach /** @var Input $INPUT */ 734*a0417606SGerry Weißbach $secToken = $this->getSecurityToken(); 735*a0417606SGerry Weißbach if ( empty( $secToken) && empty ( $token ) ) return false; 736*a0417606SGerry Weißbach if($secToken != $token) { 737*a0417606SGerry Weißbach if ( !$softfail ) msg('Security Token did not match. Possible CSRF attack.', -1); 738*a0417606SGerry Weißbach return false; 739*a0417606SGerry Weißbach } 740*a0417606SGerry Weißbach return true; 7417d101cc1SGerry Weißbach } 7427d101cc1SGerry Weißbach 743*a0417606SGerry Weißbach /** 744*a0417606SGerry Weißbach * Return a secret token to be used for CSRF attack prevention 745*a0417606SGerry Weißbach * This is known to be flawed by default 746*a0417606SGerry Weißbach * 747*a0417606SGerry Weißbach * @author Andreas Gohr <andi@splitbrain.org> 748*a0417606SGerry Weißbach * @link http://en.wikipedia.org/wiki/Cross-site_request_forgery 749*a0417606SGerry Weißbach * @link http://christ1an.blogspot.com/2007/04/preventing-csrf-efficiently.html 750*a0417606SGerry Weißbach * @link https://github.com/splitbrain/dokuwiki/issues/1883 751*a0417606SGerry Weißbach * 752*a0417606SGerry Weißbach * @return string 753*a0417606SGerry Weißbach */ 754*a0417606SGerry Weißbach function getSecurityToken() { 755*a0417606SGerry Weißbach /** @var Input $INPUT */ 756*a0417606SGerry Weißbach global $INPUT; 757*a0417606SGerry Weißbach return PassHash::hmac('md5', session_id().'siteexport', 'siteexport_salt'.auth_cookiesalt()); 758*a0417606SGerry Weißbach } 759*a0417606SGerry Weißbach}