オープンソース・ソフトウェアの開発とダウンロード

CVS リポジトリの参照

Annotation of /pukiwiki/pukiwiki/plugin/diff.inc.php

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.8 - (hide annotations) (download) (as text)
Sun Jul 18 10:12:40 2004 UTC (19 years, 10 months ago) by henoheno
Branch: MAIN
Changes since 1.7: +2 -1 lines
File MIME type: application/x-httpd-php
Blocking brute force attack

1 panda 1.1 <?php
2     /////////////////////////////////////////////////
3     // PukiWiki - Yet another WikiWikiWeb clone.
4     //
5 henoheno 1.8 // $Id: diff.inc.php,v 1.7 2004/07/18 02:58:00 henoheno Exp $
6 panda 1.1 //
7 henoheno 1.6
8 panda 1.1 //ページの差分を表示する
9     function plugin_diff_action()
10     {
11 arino 1.4 global $vars;
12 henoheno 1.6
13     $page = isset($vars['page']) ? $vars['page'] : '';
14     check_readable($page, true, true);
15    
16     $action = isset($vars['action']) ? $vars['action'] : '';
17 henoheno 1.5 switch ($action) {
18 henoheno 1.6 case 'delete': $retval = plugin_diff_delete($page); break;
19     default: $retval = plugin_diff_view($page); break;
20 arino 1.4 }
21     return $retval;
22     }
23 henoheno 1.6
24 arino 1.4 // 差分を表示
25     function plugin_diff_view($page)
26     {
27 henoheno 1.6 global $script, $hr;
28     global $_msg_notfound, $_msg_goto, $_msg_deleted, $_msg_addline, $_msg_delline, $_title_diff;
29 arino 1.4 global $_title_diff_delete;
30    
31     $r_page = rawurlencode($page);
32     $s_page = htmlspecialchars($page);
33    
34     $menu = array(
35     "<li>$_msg_addline</li>",
36     "<li>$_msg_delline</li>"
37     );
38    
39 henoheno 1.6 $is_page = is_page($page);
40     if ($is_page) {
41     $menu[] = ' <li>' . str_replace('$1', "<a href=\"$script?$r_page\">$s_page</a>", $_msg_goto) . '</li>';
42 arino 1.4 } else {
43 henoheno 1.6 $menu[] = ' <li>' . str_replace('$1', $s_page,$_msg_deleted) . '</li>';
44 panda 1.1 }
45 arino 1.4
46 henoheno 1.6 $filename = DIFF_DIR . encode($page) . '.txt';
47 arino 1.4 if (file_exists($filename)) {
48 henoheno 1.6 $diffdata = htmlspecialchars(join('', file($filename)));
49     $diffdata = preg_replace('/^(\-)(.*)$/m', '<span class="diff_removed"> $2</span>', $diffdata);
50     $diffdata = preg_replace('/^(\+)(.*)$/m', '<span class="diff_added" > $2</span>', $diffdata);
51     $menu[] = "<li><a href=\"$script?cmd=diff&action=delete&page=$r_page\">" .
52     str_replace('$1', $s_page, $_title_diff_delete) . '</a></li>';
53 arino 1.4 $msg = "<pre>$diffdata</pre>\n";
54 panda 1.1 }
55 henoheno 1.6 else if ($is_page) {
56     $diffdata = trim(htmlspecialchars(join('', get_source($page))));
57 arino 1.4 $msg = "<pre><span class=\"diff_added\">$diffdata</span></pre>\n";
58 panda 1.1 }
59     else {
60 arino 1.4 return array('msg'=>$_title_diff, 'body'=>$_msg_notfound);
61 panda 1.1 }
62 arino 1.4
63 henoheno 1.6 $menu = join("\n", $menu);
64 arino 1.4 $body = <<<EOD
65     <ul>
66     $menu
67     </ul>
68     $hr
69     EOD;
70    
71 henoheno 1.6 return array('msg'=>$_title_diff, 'body'=>$body . $msg);
72 panda 1.1 }
73 henoheno 1.6
74 arino 1.4 // バックアップを削除
75     function plugin_diff_delete($page)
76     {
77     error_reporting(E_ALL);
78    
79 henoheno 1.6 global $script, $vars, $adminpass;
80     global $_title_diff_delete, $_msg_diff_deleted;
81     global $_msg_diff_adminpass, $_btn_delete, $_msg_invalidpass;
82 arino 1.4
83 henoheno 1.6 $filename = DIFF_DIR . encode($page) . '.txt';
84     $body = '';
85 henoheno 1.7 if (! is_pagename($page)) $body = "Invalid page name";
86     if (! file_exists($filename)) $body = make_pagelink($page) . "'s diff seems not found";
87     if ($body) return array('msg'=>$_title_diff_delete, 'body'=>$body);
88 henoheno 1.6
89     if (isset($vars['pass'])) {
90     if (md5($vars['pass']) == $adminpass) {
91     unlink($filename);
92     return array(
93     'msg' => $_title_diff_delete,
94     'body' => str_replace('$1', make_pagelink($page), $_msg_diff_deleted)
95     );
96     } else {
97     $body .= "<p><strong>$_msg_invalidpass</strong></p>\n";
98 henoheno 1.8 sleep(2); // Blocking brute force attack
99 henoheno 1.6 }
100 arino 1.4 }
101    
102 henoheno 1.7 $s_page = htmlspecialchars($page);
103 arino 1.4 $body .= <<<EOD
104     <p>$_msg_diff_adminpass</p>
105     <form action="$script" method="post">
106     <div>
107 henoheno 1.6 <input type="hidden" name="cmd" value="diff" />
108     <input type="hidden" name="page" value="$s_page" />
109     <input type="hidden" name="action" value="delete" />
110     <input type="password" name="pass" size="12" />
111     <input type="submit" name="ok" value="$_btn_delete" />
112 arino 1.4 </div>
113     </form>
114     EOD;
115 henoheno 1.6
116     return array('msg'=>$_title_diff_delete, 'body'=>$body);
117 arino 1.4 }
118 panda 1.1 ?>

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26