xref: /template/strap/admin/pagerules.php (revision 32b85071e019dd3646a67c17fac4051338e495eb)
1007225e5Sgerardnico<?php
2007225e5Sgerardnico// must be run within Dokuwiki
3007225e5Sgerardnicouse ComboStrap\LogUtility;
4007225e5Sgerardnicouse ComboStrap\PageRules;
5007225e5Sgerardnicouse ComboStrap\PluginUtility;
6*32b85071SNickeauuse ComboStrap\Resources;
7007225e5Sgerardnicouse ComboStrap\Sqlite;
8007225e5Sgerardnico
9007225e5Sgerardnicoif (!defined('DOKU_INC')) die();
10007225e5Sgerardnico
11007225e5Sgerardnicoif (!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN', DOKU_INC . 'lib/plugins/');
12007225e5Sgerardnico
13007225e5Sgerardnicorequire_once(DOKU_PLUGIN . 'admin.php');
14007225e5Sgerardnicorequire_once(DOKU_INC . 'inc/parser/xhtml.php');
15007225e5Sgerardnicorequire_once(__DIR__ . '/../class/PageRules.php');
16007225e5Sgerardnicorequire_once(__DIR__ . '/../class/PluginUtility.php');
17007225e5Sgerardnico
18007225e5Sgerardnico/**
19007225e5Sgerardnico * The admin pages
20007225e5Sgerardnico * need to inherit from this class
21007225e5Sgerardnico *
22007225e5Sgerardnico *
23007225e5Sgerardnico * ! important !
24007225e5Sgerardnico * The suffix of the class name should:
25007225e5Sgerardnico *   * be equal to the name of the file
26007225e5Sgerardnico *   * and have only letters
27007225e5Sgerardnico */
28007225e5Sgerardnicoclass admin_plugin_combo_pagerules extends DokuWiki_Admin_Plugin
29007225e5Sgerardnico{
30007225e5Sgerardnico
31007225e5Sgerardnico
32007225e5Sgerardnico
33007225e5Sgerardnico    /**
34007225e5Sgerardnico     * @var array|string[]
35007225e5Sgerardnico     */
36007225e5Sgerardnico    private $infoPlugin;
37007225e5Sgerardnico
38007225e5Sgerardnico    /**
39007225e5Sgerardnico     * @var PageRules
40007225e5Sgerardnico     */
41007225e5Sgerardnico    private $pageRuleManager;
42007225e5Sgerardnico
43007225e5Sgerardnico
44007225e5Sgerardnico    /**
45007225e5Sgerardnico     * admin_plugin_combo constructor.
46007225e5Sgerardnico     *
47007225e5Sgerardnico     * Use the get function instead
48007225e5Sgerardnico     */
49007225e5Sgerardnico    public function __construct()
50007225e5Sgerardnico    {
51007225e5Sgerardnico
52007225e5Sgerardnico        // enable direct access to language strings
53007225e5Sgerardnico        // of use of $this->getLang
54007225e5Sgerardnico        $this->setupLocale();
55007225e5Sgerardnico        $this->currentDate = date("c");
56007225e5Sgerardnico        $this->infoPlugin = $this->getInfo();
57007225e5Sgerardnico
58007225e5Sgerardnico
59007225e5Sgerardnico    }
60007225e5Sgerardnico
61007225e5Sgerardnico    /**
62007225e5Sgerardnico     * Handle Sqlite instantiation  here and not in the constructor
63007225e5Sgerardnico     * to not make sqlite mandatory everywhere
64007225e5Sgerardnico     */
65007225e5Sgerardnico    private function initiatePageRuleManager()
66007225e5Sgerardnico    {
67007225e5Sgerardnico
68007225e5Sgerardnico        if ($this->pageRuleManager == null) {
69007225e5Sgerardnico
70*32b85071SNickeau            $this->pageRuleManager = new PageRules();
71007225e5Sgerardnico
72007225e5Sgerardnico        }
73007225e5Sgerardnico    }
74007225e5Sgerardnico
75007225e5Sgerardnico
76007225e5Sgerardnico    /**
77007225e5Sgerardnico     * Access for managers allowed
78007225e5Sgerardnico     */
79007225e5Sgerardnico    function forAdminOnly()
80007225e5Sgerardnico    {
81007225e5Sgerardnico        return false;
82007225e5Sgerardnico    }
83007225e5Sgerardnico
84007225e5Sgerardnico    /**
85007225e5Sgerardnico     * return sort order for position in admin menu
86007225e5Sgerardnico     */
87007225e5Sgerardnico    function getMenuSort()
88007225e5Sgerardnico    {
89007225e5Sgerardnico        return 140;
90007225e5Sgerardnico    }
91007225e5Sgerardnico
92007225e5Sgerardnico    /**
93007225e5Sgerardnico     * return prompt for admin menu
94007225e5Sgerardnico     * @param string $language
95007225e5Sgerardnico     * @return string
96007225e5Sgerardnico     */
97007225e5Sgerardnico    function getMenuText($language)
98007225e5Sgerardnico    {
99007225e5Sgerardnico        return ucfirst(PluginUtility::$PLUGIN_NAME) . " - " . $this->lang['PageRules'];
100007225e5Sgerardnico    }
101007225e5Sgerardnico
102007225e5Sgerardnico    public function getMenuIcon()
103007225e5Sgerardnico    {
104007225e5Sgerardnico        return DOKU_PLUGIN . $this->getPluginName() . '/images/page-next.svg';
105007225e5Sgerardnico    }
106007225e5Sgerardnico
107007225e5Sgerardnico
108007225e5Sgerardnico    /**
109007225e5Sgerardnico     * handle user request
110007225e5Sgerardnico     */
111007225e5Sgerardnico    function handle()
112007225e5Sgerardnico    {
113007225e5Sgerardnico
114007225e5Sgerardnico        $this->initiatePageRuleManager();
115007225e5Sgerardnico
116007225e5Sgerardnico        /**
117007225e5Sgerardnico         * If one of the form submit has the add key
118007225e5Sgerardnico         */
119007225e5Sgerardnico        if ($_POST['save'] && checkSecurityToken()) {
120007225e5Sgerardnico
121007225e5Sgerardnico            $id = $_POST[PageRules::ID_NAME];
122007225e5Sgerardnico            $matcher = $_POST[PageRules::MATCHER_NAME];
123007225e5Sgerardnico            $target = $_POST[PageRules::TARGET_NAME];
124007225e5Sgerardnico            $priority = $_POST[PageRules::PRIORITY_NAME];
125007225e5Sgerardnico
126007225e5Sgerardnico            if ($matcher == null) {
127007225e5Sgerardnico                msg('Matcher can not be null', LogUtility::LVL_MSG_ERROR);
128007225e5Sgerardnico                return;
129007225e5Sgerardnico            }
130007225e5Sgerardnico            if ($target == null) {
131007225e5Sgerardnico                msg('Target can not be null', LogUtility::LVL_MSG_ERROR);
132007225e5Sgerardnico                return;
133007225e5Sgerardnico            }
134007225e5Sgerardnico
135007225e5Sgerardnico            if ($matcher == $target) {
136007225e5Sgerardnico                msg($this->lang['SameSourceAndTargetAndPage'] . ': ' . $matcher . '', LogUtility::LVL_MSG_ERROR);
137007225e5Sgerardnico                return;
138007225e5Sgerardnico            }
139007225e5Sgerardnico
140007225e5Sgerardnico            if ($id == null) {
141007225e5Sgerardnico                if (!$this->pageRuleManager->patternExists($matcher)) {
142007225e5Sgerardnico                    $this->pageRuleManager->addRule($matcher, $target, $priority);
143007225e5Sgerardnico                    msg($this->lang['Saved'], LogUtility::LVL_MSG_INFO);
144007225e5Sgerardnico                } else {
145007225e5Sgerardnico                    msg("The matcher pattern ($matcher) already exists. The page rule was not inserted.", LogUtility::LVL_MSG_ERROR);
146007225e5Sgerardnico                }
147007225e5Sgerardnico            } else {
148007225e5Sgerardnico                $this->pageRuleManager->updateRule($id, $matcher, $target, $priority);
149007225e5Sgerardnico                msg($this->lang['Saved'], LogUtility::LVL_MSG_INFO);
150007225e5Sgerardnico            }
151007225e5Sgerardnico
152007225e5Sgerardnico
153007225e5Sgerardnico
154007225e5Sgerardnico        }
155007225e5Sgerardnico
156007225e5Sgerardnico        if ($_POST['Delete'] && checkSecurityToken()) {
157007225e5Sgerardnico
158007225e5Sgerardnico            $ruleId = $_POST[PageRules::ID_NAME];
159007225e5Sgerardnico            $this->pageRuleManager->deleteRule($ruleId);
160007225e5Sgerardnico            msg($this->lang['Deleted'], LogUtility::LVL_MSG_INFO);
161007225e5Sgerardnico
162007225e5Sgerardnico        }
163007225e5Sgerardnico
164007225e5Sgerardnico    }
165007225e5Sgerardnico
166007225e5Sgerardnico    /**
167007225e5Sgerardnico     * output appropriate html
168007225e5Sgerardnico     * TODO: Add variable parsing where the key is the key of the lang object ??
169007225e5Sgerardnico     */
170007225e5Sgerardnico    function html()
171007225e5Sgerardnico    {
172007225e5Sgerardnico
173007225e5Sgerardnico        $this->initiatePageRuleManager();
174007225e5Sgerardnico
175007225e5Sgerardnico        ptln('<h1>' . ucfirst(PluginUtility::$PLUGIN_NAME) . ' - ' . ucfirst($this->getPluginComponent()) . '</a></h1>');
176007225e5Sgerardnico        $relativePath = 'admin/' . $this->getPluginComponent() . '_intro';
177007225e5Sgerardnico        echo $this->locale_xhtml($relativePath);
178007225e5Sgerardnico
179007225e5Sgerardnico        // Forms
180007225e5Sgerardnico        if ($_POST['upsert']) {
181007225e5Sgerardnico
182007225e5Sgerardnico            $matcher = null;
183007225e5Sgerardnico            $target = null;
184007225e5Sgerardnico            $priority = 1;
185007225e5Sgerardnico
186007225e5Sgerardnico            // Update ?
187007225e5Sgerardnico            $id = $_POST[PageRules::ID_NAME];
188007225e5Sgerardnico            if ($id != null){
189007225e5Sgerardnico                $rule = $this->pageRuleManager->getRule($id);
190007225e5Sgerardnico                $matcher = $rule[PageRules::MATCHER_NAME];
191007225e5Sgerardnico                $target = $rule[PageRules::TARGET_NAME];
192007225e5Sgerardnico                $priority = $rule[PageRules::PRIORITY_NAME];
193007225e5Sgerardnico            }
194007225e5Sgerardnico
195007225e5Sgerardnico
196007225e5Sgerardnico            // Forms
197007225e5Sgerardnico            ptln('<div class="level2" >');
198007225e5Sgerardnico            ptln('<div id="form_container" style="max-width: 600px;">');
199007225e5Sgerardnico            ptln('<form action="" method="post">');
200007225e5Sgerardnico            ptln('<input type="hidden" name="sectok" value="'.getSecurityToken().'" />');
201007225e5Sgerardnico            ptln('<p><b>If the Dokuwiki ID matches the following pattern:</b></p>');
202007225e5Sgerardnico            $matcherDefault = "";
203007225e5Sgerardnico            if ($matcher != null) {
204007225e5Sgerardnico                $matcherDefault = 'value="' . $matcher . '"';
205007225e5Sgerardnico            }
206007225e5Sgerardnico            ptln('<label for="' . PageRules::MATCHER_NAME . '">(You can use the asterisk (*) character)</label>');
207007225e5Sgerardnico            ptln('<p><input type="text"  style="width: 100%;" id="' . PageRules::MATCHER_NAME . '" required="required" name="' . PageRules::MATCHER_NAME . '" ' . $matcherDefault . ' class="edit" placeholder="pattern"/> </p>');
208007225e5Sgerardnico            ptln('<p><b>Then applies this redirect settings:</b></p>');
209007225e5Sgerardnico            $targetDefault = "";
210007225e5Sgerardnico            if ($matcher != null) {
211007225e5Sgerardnico                $targetDefault = 'value="' . $target . '"';
212007225e5Sgerardnico            }
213007225e5Sgerardnico            ptln('<label for="' . PageRules::TARGET_NAME . '">Target: (A DokuWiki Id or an URL where you can use the ($) group character)</label>');
214007225e5Sgerardnico            ptln('<p><input type="text" style="width: 100%;" required="required" id="' . PageRules::TARGET_NAME . '" name="' . PageRules::TARGET_NAME . '" ' . $targetDefault . ' class="edit" placeholder="target" /></p>');
215007225e5Sgerardnico            ptln('<label for="' . PageRules::PRIORITY_NAME . '">Priority: (The order in which rules are applied)</label>');
216007225e5Sgerardnico            ptln('<p><input type="id" id="' . PageRules::PRIORITY_NAME . '." style="width: 100%;" required="required" placeholder="priority" name="' . PageRules::PRIORITY_NAME . '" value="' . $priority . '" class="edit" /></p>');
217007225e5Sgerardnico            ptln('<input type="hidden" name="do"    value="admin" />');
218007225e5Sgerardnico            if ($id != null) {
219007225e5Sgerardnico                ptln('<input type="hidden" name="' . PageRules::ID_NAME . '" value="' . $id . '" />');
220007225e5Sgerardnico            }
221007225e5Sgerardnico            ptln('<input type="hidden" name="page"  value="' . $this->getPluginName() . '_' . $this->getPluginComponent() . '" />');
222007225e5Sgerardnico            ptln('<p>');
223007225e5Sgerardnico            ptln('<a class="btn btn-light" href="?do=admin&page=webcomponent_pagerules" > ' . 'Cancel' . ' <a/>');
224007225e5Sgerardnico            ptln('<input class="btn btn-primary" type="submit" name="save" class="button" value="' . 'Save' . '" />');
225007225e5Sgerardnico            ptln('</p>');
226007225e5Sgerardnico            ptln('</form>');
227007225e5Sgerardnico            ptln('</div>');
228007225e5Sgerardnico
229007225e5Sgerardnico            ptln('</div>');
230007225e5Sgerardnico
231007225e5Sgerardnico
232007225e5Sgerardnico        } else {
233007225e5Sgerardnico
234007225e5Sgerardnico            ptln('<h2><a name="" id="pagerules_list">' . 'Rules' . '</a></h2>');
235007225e5Sgerardnico            ptln('<div class="level2">');
236007225e5Sgerardnico
237007225e5Sgerardnico            ptln('<form class="pt-3 pb-3" action="" method="post">');
238007225e5Sgerardnico            ptln('<input type="hidden" name="sectok" value="'.getSecurityToken().'" />');
239007225e5Sgerardnico            ptln('    <input type="hidden" name="do"    value="admin" />');
240007225e5Sgerardnico            ptln('	<input type="hidden" name="page"  value="' . $this->getPluginName() . '_' . $this->getPluginComponent() . '" />');
241007225e5Sgerardnico            ptln('	<input type="submit" name="upsert" name="Create a page rule" class="button" value="' . $this->getLangOrDefault('AddNewRule','Add a new rule') . '" />');
242007225e5Sgerardnico            ptln('</form>');
243007225e5Sgerardnico
244007225e5Sgerardnico            // List of redirection
245007225e5Sgerardnico            $rules = $this->pageRuleManager->getRules();
246007225e5Sgerardnico
247007225e5Sgerardnico            if (sizeof($rules)==0){
248007225e5Sgerardnico                ptln('<p>No Rules found</p>');
249007225e5Sgerardnico            } else {
250007225e5Sgerardnico                ptln('<div class="table-responsive">');
251007225e5Sgerardnico
252007225e5Sgerardnico                ptln('<table class="table table-hover">');
253007225e5Sgerardnico                ptln('	<thead>');
254007225e5Sgerardnico                ptln('		<tr>');
255007225e5Sgerardnico                ptln('			<th>&nbsp;</th>');
256007225e5Sgerardnico                ptln('			<th>' . $this->getLangOrDefault('Priority', 'Priority') . '</th>');
257007225e5Sgerardnico                ptln('			<th>' . $this->getLangOrDefault('Matcher', 'Matcher') . '</th>');
258007225e5Sgerardnico                ptln('			<th>' . $this->getLangOrDefault('Target', 'Target') . '</th>');
259007225e5Sgerardnico                ptln('			<th>' . $this->getLangOrDefault('NDate', 'Date') . '</th>');
260007225e5Sgerardnico                ptln('	    </tr>');
261007225e5Sgerardnico                ptln('	</thead>');
262007225e5Sgerardnico                ptln('	<tbody>');
263007225e5Sgerardnico
264007225e5Sgerardnico
265007225e5Sgerardnico                foreach ($rules as $key => $row) {
266007225e5Sgerardnico
267007225e5Sgerardnico                    $id = $row[PageRules::ID_NAME];
268007225e5Sgerardnico                    $matcher = $row[PageRules::MATCHER_NAME];
269007225e5Sgerardnico                    $target = $row[PageRules::TARGET_NAME];
270007225e5Sgerardnico                    $timestamp = $row[PageRules::TIMESTAMP_NAME];
271007225e5Sgerardnico                    $priority = $row[PageRules::PRIORITY_NAME];
272007225e5Sgerardnico
273007225e5Sgerardnico
274007225e5Sgerardnico                    ptln('	  <tr class="redirect_info">');
275007225e5Sgerardnico                    ptln('		<td>');
276007225e5Sgerardnico                    ptln('			<form action="" method="post" style="display: inline-block">');
277007225e5Sgerardnico                    ptln('<input type="hidden" name="sectok" value="'.getSecurityToken().'" />');
278007225e5Sgerardnico                    ptln('<button style="background: none;border: 0;">');
279*32b85071SNickeau                    ptln(inlineSVG(Resources::getImagesDirectory() . '/delete.svg'));
280007225e5Sgerardnico                    ptln('</button>');
281007225e5Sgerardnico                    ptln('				<input type="hidden" name="Delete"  value="Yes" />');
282007225e5Sgerardnico                    ptln('				<input type="hidden" name="' . PageRules::ID_NAME . '"  value="' . $id . '" />');
283007225e5Sgerardnico                    ptln('			</form>');
284007225e5Sgerardnico                    ptln('			<form action="" method="post" style="display: inline-block">');
285007225e5Sgerardnico                    ptln('<input type="hidden" name="sectok" value="'.getSecurityToken().'" />');
286007225e5Sgerardnico                    ptln('<button style="background: none;border: 0;">');
287*32b85071SNickeau                    ptln(inlineSVG(Resources::getImagesDirectory() . '/file-document-edit-outline.svg'));
288007225e5Sgerardnico                    ptln('</button>');
289007225e5Sgerardnico                    ptln('				<input type="hidden" name="upsert"  value="Yes" />');
290007225e5Sgerardnico                    ptln('				<input type="hidden" name="' . PageRules::ID_NAME . '"  value="' . $id . '" />');
291007225e5Sgerardnico                    ptln('			</form>');
292007225e5Sgerardnico
293007225e5Sgerardnico                    ptln('		</td>');
294007225e5Sgerardnico                    ptln('		<td>' . $priority . '</td>');
295007225e5Sgerardnico                    ptln('	    <td>' . $matcher . '</td>');
296007225e5Sgerardnico                    ptln('		<td>' . $target . '</td>');
297007225e5Sgerardnico                    ptln('		<td>' . $timestamp . '</td>');
298007225e5Sgerardnico                    ptln('    </tr>');
299007225e5Sgerardnico                }
300007225e5Sgerardnico                ptln('  </tbody>');
301007225e5Sgerardnico                ptln('</table>');
302007225e5Sgerardnico                ptln('</div>'); //End Table responsive
303007225e5Sgerardnico            }
304007225e5Sgerardnico
305007225e5Sgerardnico            ptln('</div>'); // End level 2
306007225e5Sgerardnico
307007225e5Sgerardnico
308007225e5Sgerardnico        }
309007225e5Sgerardnico
310007225e5Sgerardnico
311007225e5Sgerardnico    }
312007225e5Sgerardnico
313007225e5Sgerardnico    /**
314007225e5Sgerardnico     * An utility function to return the plugin translation or a default value
315007225e5Sgerardnico     * @param $id
316007225e5Sgerardnico     * @param $default
317007225e5Sgerardnico     * @return mixed|string
318007225e5Sgerardnico     */
319007225e5Sgerardnico    private function getLangOrDefault($id, $default)
320007225e5Sgerardnico    {
321007225e5Sgerardnico        $lang = $this->getLang($id);
322007225e5Sgerardnico        return $lang !='' ? $lang : $default;
323007225e5Sgerardnico    }
324007225e5Sgerardnico
325007225e5Sgerardnico
326007225e5Sgerardnico    static function getAdminPageName(){
327007225e5Sgerardnico        return PluginUtility::getAdminPageName(get_called_class());
328007225e5Sgerardnico    }
329007225e5Sgerardnico
330007225e5Sgerardnico}
331