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