OSDN Git Service

htmlsc(): Just sugar for htmlspecialchars(), and a foundation
[pukiwiki/pukiwiki.git] / plugin / lookup.inc.php
index 21689c2..5030ba7 100644 (file)
@@ -1,48 +1,65 @@
 <?php
-// $Id: lookup.inc.php,v 1.10 2004/07/31 03:09:20 henoheno Exp $
+// PukiWiki - Yet another WikiWikiWeb clone.
+// $Id: lookup.inc.php,v 1.23 2011/01/25 15:01:01 henoheno Exp $
+// Copyright (C)
+//   2002-2005 PukiWiki Developers Team
+//   2001-2002 Originally written by yu-ji
+// License: GPL v2 or (at your option) any later version
+//
+// InterWiki lookup plugin
+
+define('PLUGIN_LOOKUP_USAGE', '#lookup(interwikiname[,button_name[,default]])');
 
 function plugin_lookup_convert()
 {
-       global $script,$vars;
-
-       $args = func_get_args();
-
-       if (func_num_args() < 2) return FALSE;
-
-       $iwn = htmlspecialchars(trim(strip_tags($args[0])));
-       $btn = htmlspecialchars(trim(strip_tags($args[1])));
+       global $vars;
+       static $id = 0;
 
-       $default = '';
-       if (func_num_args() > 2)
-               $default = htmlspecialchars(trim(strip_tags($args[2])));
+       $num = func_num_args();
+       if ($num == 0 || $num > 3) return PLUGIN_LOOKUP_USAGE;
 
-       $s_page = htmlspecialchars($vars['page']);
+       $args = func_get_args();
+       $interwiki = htmlsc(trim($args[0]));
+       $button    = isset($args[1]) ? trim($args[1])         : '';
+       $button    = ($button != '') ? htmlsc($button)        : 'lookup';
+       $default   = ($num > 2)      ? htmlsc(trim($args[2])) : '';
+       $s_page    = htmlsc($vars['page']);
+       ++$id;
 
+       $script = get_script_uri();
        $ret = <<<EOD
 <form action="$script" method="post">
  <div>
   <input type="hidden" name="plugin" value="lookup" />
-  <input type="hidden" name="refer" value="$s_page" />
-  <input type="hidden" name="inter" value="$iwn" />
-  $iwn:
-  <input type="text" name="page" size="30" value="$default" />
-  <input type="submit" value="$btn" />
+  <input type="hidden" name="refer"  value="$s_page" />
+  <input type="hidden" name="inter"  value="$interwiki" />
+  <label for="_p_lookup_$id">$interwiki:</label>
+  <input type="text" name="page" id="_p_lookup_$id" size="30" value="$default" />
+  <input type="submit" value="$button" />
  </div>
 </form>
 EOD;
        return $ret;
 }
+
 function plugin_lookup_action()
 {
-       global $vars;
+       global $post; // Deny GET method to avlid GET loop
+
+       $page  = isset($post['page'])  ? $post['page']  : '';
+       $inter = isset($post['inter']) ? $post['inter'] : '';
+       if ($page == '') return FALSE; // Do nothing
+       if ($inter == '') return array('msg'=>'Invalid access', 'body'=>'');
 
-       $url = get_interwiki_url($vars['inter'],$vars['page']);
-       if ($url === FALSE)
-       {
-               return;
+       $url = get_interwiki_url($inter, $page);
+       if ($url === FALSE) {
+               $msg = sprintf('InterWikiName "%s" not found', $inter);
+               $msg = htmlsc($msg);
+               return array('msg'=>'Not found', 'body'=>$msg);
        }
 
-       header("Location: $url");
-       die();
+       pkwk_headers_sent();
+       header('Location: ' . $url); // Publish as GET method
+       exit;
 }
 ?>