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

CVS リポジトリの参照

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

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


Revision 1.8 - (show annotations) (download) (as text)
Sun Jul 18 10:12:40 2004 UTC (19 years, 9 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 <?php
2 /////////////////////////////////////////////////
3 // PukiWiki - Yet another WikiWikiWeb clone.
4 //
5 // $Id: diff.inc.php,v 1.7 2004/07/18 02:58:00 henoheno Exp $
6 //
7
8 //ページの差分を表示する
9 function plugin_diff_action()
10 {
11 global $vars;
12
13 $page = isset($vars['page']) ? $vars['page'] : '';
14 check_readable($page, true, true);
15
16 $action = isset($vars['action']) ? $vars['action'] : '';
17 switch ($action) {
18 case 'delete': $retval = plugin_diff_delete($page); break;
19 default: $retval = plugin_diff_view($page); break;
20 }
21 return $retval;
22 }
23
24 // 差分を表示
25 function plugin_diff_view($page)
26 {
27 global $script, $hr;
28 global $_msg_notfound, $_msg_goto, $_msg_deleted, $_msg_addline, $_msg_delline, $_title_diff;
29 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 $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 } else {
43 $menu[] = ' <li>' . str_replace('$1', $s_page,$_msg_deleted) . '</li>';
44 }
45
46 $filename = DIFF_DIR . encode($page) . '.txt';
47 if (file_exists($filename)) {
48 $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 $msg = "<pre>$diffdata</pre>\n";
54 }
55 else if ($is_page) {
56 $diffdata = trim(htmlspecialchars(join('', get_source($page))));
57 $msg = "<pre><span class=\"diff_added\">$diffdata</span></pre>\n";
58 }
59 else {
60 return array('msg'=>$_title_diff, 'body'=>$_msg_notfound);
61 }
62
63 $menu = join("\n", $menu);
64 $body = <<<EOD
65 <ul>
66 $menu
67 </ul>
68 $hr
69 EOD;
70
71 return array('msg'=>$_title_diff, 'body'=>$body . $msg);
72 }
73
74 // バックアップを削除
75 function plugin_diff_delete($page)
76 {
77 error_reporting(E_ALL);
78
79 global $script, $vars, $adminpass;
80 global $_title_diff_delete, $_msg_diff_deleted;
81 global $_msg_diff_adminpass, $_btn_delete, $_msg_invalidpass;
82
83 $filename = DIFF_DIR . encode($page) . '.txt';
84 $body = '';
85 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
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 sleep(2); // Blocking brute force attack
99 }
100 }
101
102 $s_page = htmlspecialchars($page);
103 $body .= <<<EOD
104 <p>$_msg_diff_adminpass</p>
105 <form action="$script" method="post">
106 <div>
107 <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 </div>
113 </form>
114 EOD;
115
116 return array('msg'=>$_title_diff_delete, 'body'=>$body);
117 }
118 ?>

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