1c677cb9fSwikidesign<?php 2c677cb9fSwikidesign/** 3c677cb9fSwikidesign * Include Plugin: Display a wiki page within another wiki page 4c677cb9fSwikidesign * 5c677cb9fSwikidesign * Action plugin component, for cache validity determination 6c677cb9fSwikidesign * 7c677cb9fSwikidesign * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 8c677cb9fSwikidesign * @author Christopher Smith <chris@jalakai.co.uk> 961053b04SMichael Klier * @author Michael Klier <chi@chimeric.de> 10c677cb9fSwikidesign */ 11c677cb9fSwikidesignif(!defined('DOKU_INC')) die(); // no Dokuwiki, no go 12c677cb9fSwikidesign 13c677cb9fSwikidesignif(!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/'); 14c677cb9fSwikidesignrequire_once(DOKU_PLUGIN.'action.php'); 15c677cb9fSwikidesign 16c677cb9fSwikidesign/** 17c677cb9fSwikidesign * All DokuWiki plugins to extend the parser/rendering mechanism 18c677cb9fSwikidesign * need to inherit from this class 19c677cb9fSwikidesign */ 20c677cb9fSwikidesignclass action_plugin_include extends DokuWiki_Action_Plugin { 21c677cb9fSwikidesign 22*1a25f14bSMichael Hamann var $supportedModes = array('xhtml'); 2361053b04SMichael Klier var $helper = null; 2461053b04SMichael Klier 2561053b04SMichael Klier function action_plugin_include() { 2661053b04SMichael Klier $this->helper = plugin_load('helper', 'include'); 2761053b04SMichael Klier } 28c677cb9fSwikidesign 29c677cb9fSwikidesign /** 30c677cb9fSwikidesign * plugin should use this method to register its handlers with the dokuwiki's event controller 31c677cb9fSwikidesign */ 32c677cb9fSwikidesign function register(&$controller) { 33c677cb9fSwikidesign $controller->register_hook('PARSER_CACHE_USE','BEFORE', $this, '_cache_prepare'); 34c44026dcSMichael Hamann $controller->register_hook('HTML_EDITFORM_OUTPUT', 'BEFORE', $this, 'handle_form'); 35c44026dcSMichael Hamann $controller->register_hook('HTML_CONFLICTFORM_OUTPUT', 'BEFORE', $this, 'handle_form'); 36c44026dcSMichael Hamann $controller->register_hook('HTML_DRAFTFORM_OUTPUT', 'BEFORE', $this, 'handle_form'); 37c44026dcSMichael Hamann $controller->register_hook('ACTION_SHOW_REDIRECT', 'BEFORE', $this, 'handle_redirect'); 386f0ad9d7SMichael Klier $controller->register_hook('PARSER_HANDLER_DONE', 'BEFORE', $this, 'handle_parser'); 397488c4d8SMichael Klier $controller->register_hook('PARSER_METADATA_RENDER', 'AFTER', $this, 'handle_metadata'); 407488c4d8SMichael Klier } 417488c4d8SMichael Klier 427488c4d8SMichael Klier /** 437488c4d8SMichael Klier * Used for debugging purposes only 447488c4d8SMichael Klier */ 457488c4d8SMichael Klier function handle_metadata(&$event, $param) { 467488c4d8SMichael Klier global $conf; 477488c4d8SMichael Klier if($conf['allowdebug']) { 487488c4d8SMichael Klier dbglog('---- PLUGIN INCLUDE META DATA START ----'); 497488c4d8SMichael Klier dbglog($event->data); 507488c4d8SMichael Klier dbglog('---- PLUGIN INCLUDE META DATA END ----'); 517488c4d8SMichael Klier } 5261053b04SMichael Klier } 5361053b04SMichael Klier 5461053b04SMichael Klier /** 5561053b04SMichael Klier * Supplies the current section level to the include syntax plugin 5661053b04SMichael Klier * 5761053b04SMichael Klier * @author Michael Klier <chi@chimeric.de> 58*1a25f14bSMichael Hamann * @author Michael Hamann <michael@content-space.de> 5961053b04SMichael Klier */ 6061053b04SMichael Klier function handle_parser(&$event, $param) { 6161053b04SMichael Klier global $ID; 6261053b04SMichael Klier 63*1a25f14bSMichael Hamann $level = 1; 6461053b04SMichael Klier $ins =& $event->data->calls; 6561053b04SMichael Klier $num = count($ins); 6661053b04SMichael Klier for($i=0; $i<$num; $i++) { 67*1a25f14bSMichael Hamann switch($ins[$i][0]) { 68*1a25f14bSMichael Hamann case 'plugin': 69e5a4d2cdSMichael Klier switch($ins[$i][1][0]) { 70e5a4d2cdSMichael Klier case 'include_include': 71*1a25f14bSMichael Hamann $ins[$i][1][1][] = $level; 72e5a4d2cdSMichael Klier break; 73*1a25f14bSMichael Hamann /* FIXME: this doesn't work anymore that way with the new structure 74e5a4d2cdSMichael Klier // some plugins already close open sections 75e5a4d2cdSMichael Klier // so we need to make sure we don't close them twice 76e5a4d2cdSMichael Klier case 'box': 77e5a4d2cdSMichael Klier $this->helper->sec_close = false; 78e5a4d2cdSMichael Klier break; 79*1a25f14bSMichael Hamann */ 80e5a4d2cdSMichael Klier } 81*1a25f14bSMichael Hamann break; 82*1a25f14bSMichael Hamann case 'section_open': 83*1a25f14bSMichael Hamann $level = $ins[$i][1][0]; 84*1a25f14bSMichael Hamann break; 8561053b04SMichael Klier } 8661053b04SMichael Klier } 87c44026dcSMichael Hamann } 88c44026dcSMichael Hamann 89c44026dcSMichael Hamann /** 906f0ad9d7SMichael Klier * Add a hidden input to the form to preserve the redirect_id 91c44026dcSMichael Hamann */ 92c44026dcSMichael Hamann function handle_form(&$event, $param) { 93c44026dcSMichael Hamann if (array_key_exists('redirect_id', $_REQUEST)) { 94c44026dcSMichael Hamann $event->data->addHidden('redirect_id', cleanID($_REQUEST['redirect_id'])); 95c44026dcSMichael Hamann } 96c44026dcSMichael Hamann } 97c44026dcSMichael Hamann 98c44026dcSMichael Hamann /** 996f0ad9d7SMichael Klier * Modify the data for the redirect when there is a redirect_id set 100c44026dcSMichael Hamann */ 101c44026dcSMichael Hamann function handle_redirect(&$event, $param) { 102c44026dcSMichael Hamann if (array_key_exists('redirect_id', $_REQUEST)) { 103c44026dcSMichael Hamann $event->data['id'] = cleanID($_REQUEST['redirect_id']); 104c44026dcSMichael Hamann $event->data['title'] = ''; 105c44026dcSMichael Hamann } 106c677cb9fSwikidesign } 107c677cb9fSwikidesign 108c677cb9fSwikidesign /** 109c677cb9fSwikidesign * prepare the cache object for default _useCache action 110c677cb9fSwikidesign */ 111c677cb9fSwikidesign function _cache_prepare(&$event, $param) { 1126f0ad9d7SMichael Klier global $ID; 1131ed2572fSMichael Klier global $INFO; 1146f0ad9d7SMichael Klier global $conf; 1156f0ad9d7SMichael Klier 116c677cb9fSwikidesign $cache =& $event->data; 117c677cb9fSwikidesign 1186f0ad9d7SMichael Klier // we're only interested in instructions of the current page 1196f0ad9d7SMichael Klier // without the ID check we'd get the cache objects for included pages as well 120babe403eSMichael Klier if(!isset($cache->page) || ($cache->page != $ID)) return; 121c677cb9fSwikidesign if(!isset($cache->mode) || !in_array($cache->mode, $this->supportedModes)) return; 122c677cb9fSwikidesign 1231ed2572fSMichael Klier if(!empty($INFO['userinfo'])) { 1241ed2572fSMichael Klier $include_key = $INFO['userinfo']['name'] . '|' . implode('|', $INFO['userinfo']['grps']); 1251ed2572fSMichael Klier } else { 1261ed2572fSMichael Klier $include_key = '@ALL'; 1271ed2572fSMichael Klier } 1281ed2572fSMichael Klier 129066f8f29SMichael Klier $depends = p_get_metadata($ID, 'plugin_include'); 1307488c4d8SMichael Klier 1317488c4d8SMichael Klier if($conf['allowdebug']) { 1327488c4d8SMichael Klier dbglog('---- PLUGIN INCLUDE INCLUDE KEY START ----'); 1337488c4d8SMichael Klier dbglog($include_key); 1347488c4d8SMichael Klier dbglog('---- PLUGIN INCLUDE INCLUDE KEY END ----'); 1357488c4d8SMichael Klier dbglog('---- PLUGIN INCLUDE CACHE DEPENDS START ----'); 1367488c4d8SMichael Klier dbglog($depends); 1377488c4d8SMichael Klier dbglog('---- PLUGIN INCLUDE CACHE DEPENDS END ----'); 1387488c4d8SMichael Klier } 1397488c4d8SMichael Klier 140ed170ea5SMichael Klier if(is_array($depends)) { 141ed170ea5SMichael Klier $pages = array(); 142ed170ea5SMichael Klier if(!isset($depends['keys'][$include_key])) { 143ed170ea5SMichael Klier $cache->depends['purge'] = true; // include key not set - request purge 144ed170ea5SMichael Klier } else { 145ed170ea5SMichael Klier $pages = $depends['pages']; 146ed170ea5SMichael Klier } 147ed170ea5SMichael Klier } else { 148ed170ea5SMichael Klier // nothing to do for us 149ed170ea5SMichael Klier return; 150ed170ea5SMichael Klier } 151c677cb9fSwikidesign 152526b0f2eSMichael Klier // add plugin.info.txt to depends for nicer upgrades 153526b0f2eSMichael Klier $cache->depends['files'][] = dirname(__FILE__) . '/plugin.info.txt'; 154621d34faSMichael Klier 1556f0ad9d7SMichael Klier $key = ''; 156*1a25f14bSMichael Hamann if (is_array($pages)) { 157ed170ea5SMichael Klier foreach($pages as $page) { 1581148b0feSMichael Klier $page = cleanID($this->helper->_apply_macro($page)); 15956820c4cSMichael Klier resolve_pageid(getNS($ID), $page, $exists); 1606f0ad9d7SMichael Klier $file = wikiFN($page); 1616f0ad9d7SMichael Klier if(!in_array($cache->depends['files'], array($file)) && @file_exists($file)) { 1626f0ad9d7SMichael Klier $cache->depends['files'][] = $file; 163298f626bSMichael Klier $key .= '#' . $page . '|ACL' . auth_quickaclcheck($page); 1646f0ad9d7SMichael Klier } 1656f0ad9d7SMichael Klier } 166*1a25f14bSMichael Hamann } 167c677cb9fSwikidesign 168c677cb9fSwikidesign // empty $key implies no includes, so nothing to do 169c677cb9fSwikidesign if(empty($key)) return; 170c677cb9fSwikidesign 171c677cb9fSwikidesign // mark the cache as being modified by the include plugin 172c677cb9fSwikidesign $cache->include = true; 173c677cb9fSwikidesign 1746f0ad9d7SMichael Klier // set new cache key & cache name 1756f0ad9d7SMichael Klier // now also dependent on included page ids and their ACL_READ status 176c677cb9fSwikidesign $cache->key .= $key; 177c677cb9fSwikidesign $cache->cache = getCacheName($cache->key, $cache->ext); 178c677cb9fSwikidesign } 179c677cb9fSwikidesign 180c677cb9fSwikidesign} 181df4e907bSMichael Klier//vim:ts=4:sw=4:et:enc=utf-8: 182