1c25e802bSgerardnico<?php 2c25e802bSgerardnico 32c067407Sgerardnicouse ComboStrap\Analytics; 4*db974367Sgerardnicouse Combostrap\AnalyticsMenuItem; 5*db974367Sgerardnicouse ComboStrap\Auth; 655d4462bSgerardnicouse ComboStrap\LogUtility; 7c25e802bSgerardnicouse ComboStrap\Page; 855d4462bSgerardnicouse ComboStrap\Sqlite; 9c25e802bSgerardnico 10c25e802bSgerardnico/** 11c25e802bSgerardnico * Copyright (c) 2021. ComboStrap, Inc. and its affiliates. All Rights Reserved. 12c25e802bSgerardnico * 13c25e802bSgerardnico * This source code is licensed under the GPL license found in the 14c25e802bSgerardnico * COPYING file in the root directory of this source tree. 15c25e802bSgerardnico * 16c25e802bSgerardnico * @license GPL 3 (https://www.gnu.org/licenses/gpl-3.0.en.html) 17c25e802bSgerardnico * @author ComboStrap <support@combostrap.com> 18c25e802bSgerardnico * 19c25e802bSgerardnico */ 20c25e802bSgerardnico 212c067407Sgerardnicorequire_once(__DIR__ . '/../class/'.'Analytics.php'); 22*db974367Sgerardnicorequire_once(__DIR__ . '/../class/'.'Auth.php'); 23*db974367Sgerardnicorequire_once(__DIR__ . '/../class/'.'AnalyticsMenuItem.php'); 242c067407Sgerardnico 25c25e802bSgerardnico/** 26c25e802bSgerardnico * Class action_plugin_combo_analytics 27c25e802bSgerardnico * Update the analytics data 28c25e802bSgerardnico */ 29c25e802bSgerardnicoclass action_plugin_combo_analytics extends DokuWiki_Action_Plugin 30c25e802bSgerardnico{ 31c25e802bSgerardnico 32c25e802bSgerardnico 33c25e802bSgerardnico public function register(Doku_Event_Handler $controller) 34c25e802bSgerardnico { 352c067407Sgerardnico 36c25e802bSgerardnico /** 37c42a1196Sgerardnico * Analytics to refresh because they have lost or gain a backlinks 38c42a1196Sgerardnico * are done via Sqlite table (The INDEXER_TASKS_RUN gives a way to 39c42a1196Sgerardnico * manipulate this queue) 40266b617eSgerardnico * 41266b617eSgerardnico * There is no need to do it at page write 42266b617eSgerardnico * https://www.dokuwiki.org/devel:event:io_wikipage_write 43266b617eSgerardnico * because after the page is written, the page is shown and trigger the index tasks run 44c42a1196Sgerardnico */ 4555d4462bSgerardnico $controller->register_hook('INDEXER_TASKS_RUN', 'BEFORE', $this, 'handle_refresh_analytics', array()); 4655d4462bSgerardnico 47*db974367Sgerardnico /** 48*db974367Sgerardnico * Add a icon in the page tools menu 49*db974367Sgerardnico * https://www.dokuwiki.org/devel:event:menu_items_assembly 50*db974367Sgerardnico */ 51*db974367Sgerardnico $controller->register_hook('MENU_ITEMS_ASSEMBLY', 'AFTER', $this, 'handle_page_tools'); 52*db974367Sgerardnico 53c25e802bSgerardnico } 54c25e802bSgerardnico 5555d4462bSgerardnico public function handle_refresh_analytics(Doku_Event $event, $param) 5655d4462bSgerardnico { 5755d4462bSgerardnico 58c42a1196Sgerardnico /** 59c42a1196Sgerardnico * Check that the actual page has analytics data 60c42a1196Sgerardnico * (if there is a cache, it's pretty quick) 61c42a1196Sgerardnico */ 62c42a1196Sgerardnico global $ID; 63c42a1196Sgerardnico Analytics::process($ID,true); 64c42a1196Sgerardnico 65c42a1196Sgerardnico /** 66c42a1196Sgerardnico * Check the analytics to refresh 67c42a1196Sgerardnico */ 6855d4462bSgerardnico $sqlite = Sqlite::getSqlite(); 6955d4462bSgerardnico $res = $sqlite->query("SELECT ID FROM ANALYTICS_TO_REFRESH"); 7055d4462bSgerardnico if (!$res) { 7155d4462bSgerardnico LogUtility::msg("There was a problem during the select: {$sqlite->getAdapter()->getDb()->errorInfo()}"); 7255d4462bSgerardnico } 7355d4462bSgerardnico $rows = $sqlite->res2arr($res,true); 7455d4462bSgerardnico $sqlite->res_close($res); 7555d4462bSgerardnico foreach($rows as $row){ 7655d4462bSgerardnico $page = new Page($row['ID']); 7755d4462bSgerardnico $page->refreshAnalytics(); 7855d4462bSgerardnico } 7955d4462bSgerardnico 8055d4462bSgerardnico } 81*db974367Sgerardnico 82*db974367Sgerardnico public function handle_page_tools(Doku_Event $event, $param){ 83*db974367Sgerardnico 84*db974367Sgerardnico if (!Auth::isLoggedIn()){ 85*db974367Sgerardnico return; 86*db974367Sgerardnico } 87*db974367Sgerardnico 88*db974367Sgerardnico /** 89*db974367Sgerardnico * The `view` property defines the menu that is currently built 90*db974367Sgerardnico * https://www.dokuwiki.org/devel:menus 91*db974367Sgerardnico * If this is not the page menu, return 92*db974367Sgerardnico */ 93*db974367Sgerardnico if($event->data['view'] != 'page') return; 94*db974367Sgerardnico 95*db974367Sgerardnico global $INFO; 96*db974367Sgerardnico if(!$INFO['exists']) { 97*db974367Sgerardnico return; 98*db974367Sgerardnico } 99*db974367Sgerardnico array_splice($event->data['items'], -1, 0, array(new AnalyticsMenuItem())); 100*db974367Sgerardnico 101*db974367Sgerardnico } 102c25e802bSgerardnico} 103c25e802bSgerardnico 104c25e802bSgerardnico 105c25e802bSgerardnico 106