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