register_hook('TPL_ACT_RENDER', 'AFTER', $this, 'handle_diff_accept'); $controller->register_hook('HTML_SHOWREV_OUTPUT', 'BEFORE', $this, 'handle_showrev'); $controller->register_hook('ACTION_ACT_PREPROCESS', 'BEFORE', $this, 'handle_approve'); $controller->register_hook('ACTION_ACT_PREPROCESS', 'BEFORE', $this, 'handle_mark_ready_for_approval'); $controller->register_hook('ACTION_ACT_PREPROCESS', 'BEFORE', $this, 'handle_viewer'); $controller->register_hook('TPL_ACT_RENDER', 'BEFORE', $this, 'handle_display_banner'); $controller->register_hook('COMMON_WIKIPAGE_SAVE', 'AFTER', $this, 'handle_pagesave_after'); } /** * @param Doku_Event $event */ public function handle_diff_accept(Doku_Event $event) { global $INFO; try { /** @var \helper_plugin_approve_db $db_helper */ $db_helper = plugin_load('helper', 'approve_db'); $sqlite = $db_helper->getDB(); } catch (Exception $e) { msg($e->getMessage(), -1); return; } /** @var helper_plugin_approve $helper */ $helper = plugin_load('helper', 'approve'); if (!$helper->use_approve_here($sqlite, $INFO['id'])) return; if ($event->data == 'diff' && isset($_GET['approve'])) { $href = wl($INFO['id'], ['approve' => 'approve']); ptln(''.$this->getLang('approve').''); } if ($this->getConf('ready_for_approval') && $event->data == 'diff' && isset($_GET['ready_for_approval'])) { $href = wl($INFO['id'], ['ready_for_approval' => 'ready_for_approval']); ptln(''.$this->getLang('approve_ready').''); } } /** * @param Doku_Event $event */ public function handle_showrev(Doku_Event $event) { global $INFO; try { /** @var \helper_plugin_approve_db $db_helper */ $db_helper = plugin_load('helper', 'approve_db'); $sqlite = $db_helper->getDB(); } catch (Exception $e) { msg($e->getMessage(), -1); return; } /** @var helper_plugin_approve $helper */ $helper = plugin_load('helper', 'approve'); if (!$helper->use_approve_here($sqlite, $INFO['id'])) return; $last_approved_rev = $helper->find_last_approved($sqlite, $INFO['id']); if ($last_approved_rev == $INFO['rev']) { $event->preventDefault(); } } /** * @param Doku_Event $event */ public function handle_approve(Doku_Event $event) { global $INFO; try { /** @var \helper_plugin_approve_db $db_helper */ $db_helper = plugin_load('helper', 'approve_db'); $sqlite = $db_helper->getDB(); } catch (Exception $e) { msg($e->getMessage(), -1); return; } /** @var helper_plugin_approve $helper */ $helper = plugin_load('helper', 'approve'); if ($event->data != 'show') return; if (!isset($_GET['approve'])) return; if (!$helper->use_approve_here($sqlite, $INFO['id'], $approver)) return; if (!$helper->client_can_approve($INFO['id'], $approver)) return; $res = $sqlite->query('SELECT MAX(version)+1 FROM revision WHERE page=?', $INFO['id']); $next_version = $sqlite->res2single($res); if (!$next_version) { $next_version = 1; } //approved IS NULL prevents from overriding already approved page $sqlite->query('UPDATE revision SET approved=?, approved_by=?, version=? WHERE page=? AND current=1 AND approved IS NULL', date('c'), $INFO['client'], $next_version, $INFO['id']); header('Location: ' . wl($INFO['id'])); } /** * @param Doku_Event $event */ public function handle_mark_ready_for_approval(Doku_Event $event) { global $INFO; try { /** @var \helper_plugin_approve_db $db_helper */ $db_helper = plugin_load('helper', 'approve_db'); $sqlite = $db_helper->getDB(); } catch (Exception $e) { msg($e->getMessage(), -1); return; } /** @var helper_plugin_approve $helper */ $helper = plugin_load('helper', 'approve'); if ($event->data != 'show') return; if (!isset($_GET['ready_for_approval'])) return; if (!$helper->use_approve_here($sqlite, $INFO['id'])) return; if (!$helper->client_can_mark_ready_for_approval($INFO['id'])) return; $sqlite->query('UPDATE revision SET ready_for_approval=?, ready_for_approval_by=? WHERE page=? AND current=1 AND ready_for_approval IS NULL', date('c'), $INFO['client'], $INFO['id']); header('Location: ' . wl($INFO['id'])); } /** * Redirect to newest approved page for user that don't have EDIT permission. * * @param Doku_Event $event */ public function handle_viewer(Doku_Event $event) { global $INFO; try { /** @var \helper_plugin_approve_db $db_helper */ $db_helper = plugin_load('helper', 'approve_db'); $sqlite = $db_helper->getDB(); } catch (Exception $e) { msg($e->getMessage(), -1); return; } /** @var helper_plugin_approve $helper */ $helper = plugin_load('helper', 'approve'); if ($event->data != 'show') return; //apply only to current page if ($INFO['rev'] != 0) return; if (!$helper->use_approve_here($sqlite, $INFO['id'], $approver)) return; if ($helper->client_can_see_drafts($INFO['id'], $approver)) return; $last_approved_rev = $helper->find_last_approved($sqlite, $INFO['id']); //no page is approved if (!$last_approved_rev) return; $last_change_date = @filemtime(wikiFN($INFO['id'])); //current page is approved if ($last_approved_rev == $last_change_date) return; header("Location: " . wl($INFO['id'], ['rev' => $last_approved_rev], false, '&')); } /** * @param Doku_Event $event */ public function handle_display_banner(Doku_Event $event) { global $INFO, $ID; /* Return true if banner should not be displayed for users with or below read only permission. */ if (auth_quickaclcheck($ID) <= AUTH_READ && !$this->getConf('display_banner_for_readonly')) { return true; } /* Not returned - rendering the banner */ try { /** @var \helper_plugin_approve_db $db_helper */ $db_helper = plugin_load('helper', 'approve_db'); $sqlite = $db_helper->getDB(); } catch (Exception $e) { msg($e->getMessage(), -1); return; } /** @var helper_plugin_approve $helper */ $helper = plugin_load('helper', 'approve'); if ($event->data != 'show') return; if (!$INFO['exists']) return; if (!$helper->use_approve_here($sqlite, $INFO['id'], $approver)) return; // $last_change_date = p_get_metadata($INFO['id'], 'last_change date'); $last_change_date = @filemtime(wikiFN($INFO['id'])); $rev = !$INFO['rev'] ? $last_change_date : $INFO['rev']; $res = $sqlite->query('SELECT ready_for_approval, ready_for_approval_by, approved, approved_by, version FROM revision WHERE page=? AND rev=?', $INFO['id'], $rev); $approve = $sqlite->res_fetch_assoc($res); $last_approved_rev = $helper->find_last_approved($sqlite, $INFO['id']); $classes = []; if ($this->getConf('prettyprint')) { $classes[] = 'plugin__approve_noprint'; } if ($approve['approved'] && $rev == $last_approved_rev) { $classes[] = 'plugin__approve_approved'; } elseif ($approve['approved']) { $classes[] = 'plugin__approve_old_approved'; } elseif ($this->getConf('ready_for_approval') && $approve['ready_for_approval']) { $classes[] = 'plugin__approve_ready'; } else { $classes[] = 'plugin__approve_draft'; } ptln('