OSDN Git Service

BugTrack/2420 AutoTicketLink - Improve regex and JSON encode
[pukiwiki/pukiwiki.git] / plugin / rename.inc.php
index f036217..f85e1d7 100644 (file)
@@ -1,13 +1,18 @@
 <?php
 // PukiWiki - Yet another WikiWikiWeb clone
-// $Id: rename.inc.php,v 1.23 2005/01/23 08:08:00 henoheno Exp $
+// rename.inc.php
+// Copyright 2002-2018 PukiWiki Development Team
+// License: GPL v2 or (at your option) any later version
 //
 // Rename plugin: Rename page-name and related data
 //
-// Usage: http://path/to/pukiwikiphp?plugin=rename[&refer=page_name]
+// Usage: http://path/to/index.php?plugin=rename[&refer=page_name]
 
 define('PLUGIN_RENAME_LOGPAGE', ':RenameLog');
 
+if (file_exists(PLUGIN_DIR . 'counter.inc.php'))
+       require_once(PLUGIN_DIR . 'counter.inc.php');
+
 function plugin_rename_action()
 {
        global $whatsnew;
@@ -20,7 +25,7 @@ function plugin_rename_action()
                if ($src == '') return plugin_rename_phase1();
 
                $src_pattern = '/' . preg_quote($src, '/') . '/';
-               $arr0 = preg_grep($src_pattern, get_existpages());
+               $arr0 = preg_grep($src_pattern, plugin_rename_get_existpages());
                if (! is_array($arr0) || empty($arr0))
                        return plugin_rename_phase1('nomatch');
 
@@ -40,13 +45,13 @@ function plugin_rename_action()
                if ($refer == '') {
                        return plugin_rename_phase1();
 
-               } else if (! is_page($refer)) {
+               } else if (! plugin_rename_is_page($refer)) {
                        return plugin_rename_phase1('notpage', $refer);
 
-               } else if ($refer == $whatsnew) {
+               } else if ($refer === $whatsnew) {
                        return plugin_rename_phase1('norename', $refer);
 
-               } else if ($page == '' || $page == $refer) {
+               } else if ($page == '' || $page === $refer) {
                        return plugin_rename_phase2();
 
                } else if (! is_pagename($page)) {
@@ -58,14 +63,14 @@ function plugin_rename_action()
        }
 }
 
-// ÊÑ¿ô¤ò¼èÆÀ¤¹¤ë
+// 変数を取得する
 function plugin_rename_getvar($key)
 {
        global $vars;
        return isset($vars[$key]) ? $vars[$key] : '';
 }
 
-// ¥¨¥é¡¼¥á¥Ã¥»¡¼¥¸¤òºî¤ë
+// エラーメッセージを作る
 function plugin_rename_err($err, $page = '')
 {
        global $_rename_messages;
@@ -78,47 +83,48 @@ function plugin_rename_err($err, $page = '')
                foreach ($page as $_page) $tmp .= '<br />' . $_page;
                $page = $tmp;
        }
-       if ($page != '') $body = sprintf($body, htmlspecialchars($page));
+       if ($page != '') $body = sprintf($body, htmlsc($page));
 
        $msg = sprintf($_rename_messages['err'], $body);
        return $msg;
 }
 
-//Âè°ìÃʳ¬:¥Ú¡¼¥¸Ì¾¤Þ¤¿¤ÏÀµµ¬É½¸½¤ÎÆþÎÏ
+//第一段階:ページ名または正規表現の入力
 function plugin_rename_phase1($err = '', $page = '')
 {
-       global $script, $_rename_messages;
+       global $_rename_messages;
 
+       $script = get_base_uri();
        $msg    = plugin_rename_err($err, $page);
        $refer  = plugin_rename_getvar('refer');
        $method = plugin_rename_getvar('method');
 
        $radio_regex = $radio_page = '';
        if ($method == 'regex') {
-               $radio_regex =' checked';
+               $radio_regex = ' checked="checked"';
        } else {
-               $radio_page = ' checked';
+               $radio_page  = ' checked="checked"';
        }
        $select_refer = plugin_rename_getselecttag($refer);
 
-       $s_src = htmlspecialchars(plugin_rename_getvar('src'));
-       $s_dst = htmlspecialchars(plugin_rename_getvar('dst'));
+       $s_src = htmlsc(plugin_rename_getvar('src'));
+       $s_dst = htmlsc(plugin_rename_getvar('dst'));
 
        $ret = array();
-       $ret['msg'] = $_rename_messages['msg_title'];
+       $ret['msg']  = $_rename_messages['msg_title'];
        $ret['body'] = <<<EOD
 $msg
 <form action="$script" method="post">
  <div>
   <input type="hidden" name="plugin" value="rename" />
-  <input type="radio"  name="method" value="page"$radio_page />
-  {$_rename_messages['msg_page']}:$select_refer<br />
-  <input type="radio" name="method" value="regex"$radio_regex />
-  {$_rename_messages['msg_regex']}:<br />
-  From:<br />
-  <input type="text" name="src" size="80" value="$s_src" /><br />
-  To:<br />
-  <input type="text" name="dst" size="80" value="$s_dst" /><br />
+  <input type="radio"  name="method" id="_p_rename_page" value="page"$radio_page />
+  <label for="_p_rename_page">{$_rename_messages['msg_page']}:</label>$select_refer<br />
+  <input type="radio"  name="method" id="_p_rename_regex" value="regex"$radio_regex />
+  <label for="_p_rename_regex">{$_rename_messages['msg_regex']}:</label><br />
+  <label for="_p_rename_from">From:</label><br />
+  <input type="text" name="src" id="_p_rename_from" size="80" value="$s_src" /><br />
+  <label for="_p_rename_to">To:</label><br />
+  <input type="text" name="dst" id="_p_rename_to"   size="80" value="$s_dst" /><br />
   <input type="submit" value="{$_rename_messages['btn_next']}" /><br />
  </div>
 </form>
@@ -126,11 +132,12 @@ EOD;
        return $ret;
 }
 
-//ÂèÆóÃʳ¬:¿·¤·¤¤Ì¾Á°¤ÎÆþÎÏ
+//第二段階:新しい名前の入力
 function plugin_rename_phase2($err = '')
 {
-       global $script, $_rename_messages;
+       global $_rename_messages;
 
+       $script = get_base_uri();
        $msg   = plugin_rename_err($err);
        $page  = plugin_rename_getvar('page');
        $refer = plugin_rename_getvar('refer');
@@ -139,12 +146,12 @@ function plugin_rename_phase2($err = '')
        $msg_related = '';
        $related = plugin_rename_getrelated($refer);
        if (! empty($related))
-               $msg_related = $_rename_messages['msg_do_related'] .
-                       '<input type="checkbox" name="related" value="1" checked="checked" /><br />';
+               $msg_related = '<label for="_p_rename_related">' . $_rename_messages['msg_do_related'] . '</label>' .
+               '<input type="checkbox" name="related" id="_p_rename_related" value="1" checked="checked" /><br />';
 
        $msg_rename = sprintf($_rename_messages['msg_rename'], make_pagelink($refer));
-       $s_page  = htmlspecialchars($page);
-       $s_refer = htmlspecialchars($refer);
+       $s_page  = htmlsc($page);
+       $s_refer = htmlsc($refer);
 
        $ret = array();
        $ret['msg']  = $_rename_messages['msg_title'];
@@ -155,7 +162,8 @@ $msg
   <input type="hidden" name="plugin" value="rename" />
   <input type="hidden" name="refer"  value="$s_refer" />
   $msg_rename<br />
-  {$_rename_messages['msg_newname']}:<input type="text" name="page" size="80" value="$s_page" /><br />
+  <label for="_p_rename_newname">{$_rename_messages['msg_newname']}:</label>
+  <input type="text" name="page" id="_p_rename_newname" size="80" value="$s_page" /><br />
   $msg_related
   <input type="submit" value="{$_rename_messages['btn_next']}" /><br />
  </div>
@@ -163,7 +171,7 @@ $msg
 EOD;
        if (! empty($related)) {
                $ret['body'] .= '<hr /><p>' . $_rename_messages['msg_related'] . '</p><ul>';
-               sort($related);
+               sort($related, SORT_STRING);
                foreach ($related as $name)
                        $ret['body'] .= '<li>' . make_pagelink($name) . '</li>';
                $ret['body'] .= '</ul>';
@@ -171,7 +179,7 @@ EOD;
        return $ret;
 }
 
-//¥Ú¡¼¥¸Ì¾¤È´ØÏ¢¤¹¤ë¥Ú¡¼¥¸¤òÎóµó¤·¡¢phase3¤Ø
+//ページ名と関連するページを列挙し、phase3へ
 function plugin_rename_refer()
 {
        $page  = plugin_rename_getvar('page');
@@ -187,7 +195,7 @@ function plugin_rename_refer()
        return plugin_rename_phase3($pages);
 }
 
-//Àµµ¬É½¸½¤Ç¥Ú¡¼¥¸¤òÃÖ´¹
+//正規表現でページを置換
 function plugin_rename_regex($arr_from, $arr_to)
 {
        $exists = array();
@@ -207,8 +215,9 @@ function plugin_rename_regex($arr_from, $arr_to)
 
 function plugin_rename_phase3($pages)
 {
-       global $script, $_rename_messages;
+       global $_rename_messages;
 
+       $script = get_base_uri();
        $msg = $input = '';
        $files = plugin_rename_get_files($pages);
 
@@ -227,16 +236,16 @@ function plugin_rename_phase3($pages)
 
        $method = plugin_rename_getvar('method');
        if ($method == 'regex') {
-               $s_src = htmlspecialchars(plugin_rename_getvar('src'));
-               $s_dst = htmlspecialchars(plugin_rename_getvar('dst'));
+               $s_src = htmlsc(plugin_rename_getvar('src'));
+               $s_dst = htmlsc(plugin_rename_getvar('dst'));
                $msg   .= $_rename_messages['msg_regex'] . '<br />';
                $input .= '<input type="hidden" name="method" value="regex" />';
                $input .= '<input type="hidden" name="src"    value="' . $s_src . '" />';
                $input .= '<input type="hidden" name="dst"    value="' . $s_dst . '" />';
        } else {
-               $s_refer   = htmlspecialchars(plugin_rename_getvar('refer'));
-               $s_page    = htmlspecialchars(plugin_rename_getvar('page'));
-               $s_related = htmlspecialchars(plugin_rename_getvar('related'));
+               $s_refer   = htmlsc(plugin_rename_getvar('refer'));
+               $s_page    = htmlsc(plugin_rename_getvar('page'));
+               $s_related = htmlsc(plugin_rename_getvar('related'));
                $msg   .= $_rename_messages['msg_page'] . '<br />';
                $input .= '<input type="hidden" name="method"  value="page" />';
                $input .= '<input type="hidden" name="refer"   value="' . $s_refer   . '" />';
@@ -249,7 +258,7 @@ function plugin_rename_phase3($pages)
                foreach ($exists as $page=>$arr) {
                        $msg .= '<li>' . make_pagelink(decode($page));
                        $msg .= $_rename_messages['msg_arrow'];
-                       $msg .= htmlspecialchars(decode($pages[$page]));
+                       $msg .= htmlsc(decode($pages[$page]));
                        if (! empty($arr)) {
                                $msg .= '<ul>' . "\n";
                                foreach ($arr as $ofile=>$nfile)
@@ -275,20 +284,20 @@ function plugin_rename_phase3($pages)
  <div>
   <input type="hidden" name="plugin" value="rename" />
   $input
-  {$_rename_messages['msg_adminpass']}
-  <input type="password" name="pass" value="" />
+  <label for="_p_rename_adminpass">{$_rename_messages['msg_adminpass']}</label>
+  <input type="password" name="pass" id="_p_rename_adminpass" value="" />
   <input type="submit" value="{$_rename_messages['btn_submit']}" />
  </div>
 </form>
 <p>{$_rename_messages['msg_confirm']}</p>
 EOD;
 
-       ksort($pages);
+       ksort($pages, SORT_STRING);
        $ret['body'] .= '<ul>' . "\n";
        foreach ($pages as $old=>$new)
                $ret['body'] .= '<li>' .  make_pagelink(decode($old)) .
                        $_rename_messages['msg_arrow'] .
-                       htmlspecialchars(decode($new)) .  '</li>' . "\n";
+                       htmlsc(decode($new)) .  '</li>' . "\n";
        $ret['body'] .= '</ul>' . "\n";
        return $ret;
 }
@@ -304,18 +313,16 @@ function plugin_rename_get_files($pages)
        $matches = array();
        foreach ($dirs as $path) {
                $dir = opendir($path);
-               if (! $dir) continue;
-
-               while ($file = readdir($dir)) {
+               if (! $dir) continue;   // TODO: !== FALSE or die()?
+               while (($file = readdir($dir)) !== FALSE) {
                        if ($file == '.' || $file == '..') continue;
-
-                       foreach ($pages as $from=>$to) {
+                       foreach ($pages as $from => $to) {
+                               // TODO: preg_quote()?
                                $pattern = '/^' . str_replace('/', '\/', $from) . '([._].+)$/';
-                               if (! preg_match($pattern, $file, $matches))
-                                       continue;
-
-                               $newfile = $to . $matches[1];
-                               $files[$from][$path . $file] = $path . $newfile;
+                               if (preg_match($pattern, $file, $matches)) {
+                                       $newfile = $to . $matches[1];
+                                       $files[$from][$path . $file] = $path . $newfile;
+                               }
                        }
                }
        }
@@ -336,12 +343,18 @@ function plugin_rename_proceed($pages, $files, $exists)
                        if (isset($exists[$page][$old]) && $exists[$page][$old])
                                unlink($new);
                        rename($old, $new);
-
-                       // link¥Ç¡¼¥¿¥Ù¡¼¥¹¤ò¹¹¿·¤¹¤ë BugTrack/327 arino
-                       links_update($old);
-                       links_update($new);
                }
+               // linkデータベースを更新する BugTrack/327 arino
+               $new_page = $pages[$page];
+               links_update(decode($page));
+               links_update(decode($new_page));
+       }
+       // Rename counter
+       $pages_decoded = array();
+       foreach ($pages as $old=>$new) {
+               $pages_decoded[decode($old)] = decode($new);
        }
+       plugin_counter_page_rename($pages_decoded);
 
        $postdata = get_source(PLUGIN_RENAME_LOGPAGE);
        $postdata[] = '*' . $now . "\n";
@@ -371,27 +384,30 @@ function plugin_rename_proceed($pages, $files, $exists)
                $postdata[] = '-' . decode($old) .
                        $_rename_messages['msg_arrow'] . decode($new) . "\n";
 
-       // ¹¹¿·¤Î¾×ÆͤϥÁ¥§¥Ã¥¯¤·¤Ê¤¤¡£
+       // 更新の衝突はチェックしない。
 
-       // ¥Õ¥¡¥¤¥ë¤Î½ñ¤­¹þ¤ß
+       // ファイルの書き込み
        page_write(PLUGIN_RENAME_LOGPAGE, join('', $postdata));
 
-       //¥ê¥À¥¤¥ì¥¯¥È
+       // Refresh RecentChanges / Delete cache/recent.dat
+       delete_recent_changes_cache();
+
+       //リダイレクト
        $page = plugin_rename_getvar('page');
        if ($page == '') $page = PLUGIN_RENAME_LOGPAGE;
 
        pkwk_headers_sent();
-       header('Location: ' . get_script_uri() . '?' . rawurlencode($page));
+       header('Location: ' . get_page_uri($page, PKWK_URI_ROOT));
        exit;
 }
 
 function plugin_rename_getrelated($page)
 {
        $related = array();
-       $pages = get_existpages();
+       $pages = plugin_rename_get_existpages();
        $pattern = '/(?:^|\/)' . preg_quote(strip_bracket($page), '/') . '(?:\/|$)/';
        foreach ($pages as $name) {
-               if ($name == $page) continue;
+               if ($name === $page) continue;
                if (preg_match($pattern, $name)) $related[] = $name;
        }
        return $related;
@@ -402,15 +418,15 @@ function plugin_rename_getselecttag($page)
        global $whatsnew;
 
        $pages = array();
-       foreach (get_existpages() as $_page) {
-               if ($_page == $whatsnew) continue;
+       foreach (plugin_rename_get_existpages() as $_page) {
+               if ($_page === $whatsnew) continue;
 
-               $selected = ($_page == $page) ? ' selected' : '';
-               $s_page = htmlspecialchars($_page);
+               $selected = ($_page === $page) ? ' selected' : '';
+               $s_page = htmlsc($_page);
                $pages[$_page] = '<option value="' . $s_page . '"' . $selected . '>' .
                        $s_page . '</option>';
        }
-       ksort($pages);
+       ksort($pages, SORT_STRING);
        $list = join("\n" . ' ', $pages);
 
        return <<<EOD
@@ -421,4 +437,51 @@ function plugin_rename_getselecttag($page)
 EOD;
 
 }
-?>
+
+/**
+ * List exist pages and deleted pages
+ */
+function plugin_rename_get_existpages() {
+       $list1 = array_values(get_existpages());
+       $list2 = array_values(get_existpages(DIFF_DIR, '.txt'));
+       $list3 = array_values(get_existpages(BACKUP_DIR, '.txt'));
+       $list4 = array_values(get_existpages(BACKUP_DIR, '.gz'));
+       $list5 = array_values(get_existpages(COUNTER_DIR, '.count'));
+       $wholelist = array_merge($list1, $list2, $list3, $list4, $list5);
+       $list = array_unique($wholelist);
+       return $list;
+}
+
+/**
+ * Return where the page exists or existed
+ */
+function plugin_rename_is_page($page) {
+       $enc = encode($page);
+       if (is_page($page)) {
+               return true;
+       }
+       if (file_exists(DIFF_DIR . $enc . '.txt')) {
+               return true;
+       }
+       if (file_exists(BACKUP_DIR . $enc . '.txt')) {
+               return true;
+       }
+       if (file_exists(BACKUP_DIR . $enc . '.gz')) {
+               return true;
+       }
+       if (file_exists(COUNTER_DIR . $enc . '.count')) {
+               return true;
+       }
+       return false;
+}
+
+/**
+ * Setup initial pages (:RenameLog)
+ */
+function plugin_rename_setup_initial_pages() {
+       if (!is_page(PLUGIN_RENAME_LOGPAGE)) {
+               // Create :RenameLog
+               $body = "#freeze\n// :RenameLog (rename plugin)\n";
+               page_write(PLUGIN_RENAME_LOGPAGE, $body);
+       }
+}