xref: /plugin/combo/action/analytics.php (revision db974367315cd79e2d16d5351fdc5515274623a7)
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