OSDN Git Service

BugTrack/791: Fix typo 0,91 => 0.91
[pukiwiki/pukiwiki.git] / plugin / article.inc.php
index a6b3d57..79743eb 100644 (file)
 <?php
+// $Id: article.inc.php,v 1.22 2005/01/23 07:01:56 henoheno Exp $
  /*
+
  PukiWiki BBSÉ÷¥×¥é¥°¥¤¥ó
 
  CopyRight 2002 OKAWARA,Satoshi
  http://www.dml.co.jp/~kawara/pukiwiki/pukiwiki.php
  kawara@dml.co.jp
+
  ¥á¥Ã¥»¡¼¥¸¤òÊѹ¹¤·¤¿¤¤¾ì¹ç¤ÏLANGUAGE¥Õ¥¡¥¤¥ë¤Ë²¼µ­¤ÎÃͤòÄɲ䷤Ƥ«¤é¤´»ÈÍѤ¯¤À¤µ¤¤
        $_btn_name = '¤ªÌ¾Á°';
        $_btn_article = 'µ­»ö¤ÎÅê¹Æ';
        $_btn_subject = 'Âê̾: ';
 
  ¢¨$_btn_name¤Ïcomment¥×¥é¥°¥¤¥ó¤Ç´û¤ËÀßÄꤵ¤ì¤Æ¤¤¤ë¾ì¹ç¤¬¤¢¤ê¤Þ¤¹
+
  Åê¹ÆÆâÍƤμ«Æ°¥á¡¼¥ëžÁ÷µ¡Ç½¤ò¤´»ÈÍѤˤʤꤿ¤¤¾ì¹ç¤Ï
  -Åê¹ÆÆâÍƤΥ᡼¥ë¼«Æ°ÇÛ¿®
  -Åê¹ÆÆâÍƤΥ᡼¥ë¼«Æ°ÇÛ¿®Àè
  ¤òÀßÄê¤Î¾å¡¢¤´»ÈÍѤ¯¤À¤µ¤¤¡£
 
- $Id: article.inc.php,v 1.13 2003/04/17 02:25:18 arino Exp $
  */
 
-global $_mailto;
-
-/////////////////////////////////////////////////
-// ¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¥«¥é¥à¿ô
-define('article_COLS',70);
-/////////////////////////////////////////////////
-// ¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¹Ô¿ô
-define('article_ROWS',5);
-/////////////////////////////////////////////////
-// Ì¾Á°¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¥«¥é¥à¿ô
-define('NAME_COLS',24);
-/////////////////////////////////////////////////
-// Âê̾¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¥«¥é¥à¿ô
-define('SUBJECT_COLS',60);
-/////////////////////////////////////////////////
-// Ì¾Á°¤ÎÁÞÆþ¥Õ¥©¡¼¥Þ¥Ã¥È
-define('NAME_FORMAT','[[$name]]');
-/////////////////////////////////////////////////
-// Âê̾¤ÎÁÞÆþ¥Õ¥©¡¼¥Þ¥Ã¥È
-define('SUBJECT_FORMAT','**$subject');
-/////////////////////////////////////////////////
-// Âê̾¤¬Ì¤µ­Æþ¤Î¾ì¹ç¤Îɽµ­ 
-define('NO_SUBJECT','̵Âê');
-/////////////////////////////////////////////////
-// ÁÞÆþ¤¹¤ë°ÌÃÖ 1:Íó¤ÎÁ° 0:Íó¤Î¸å
-define('ARTICLE_INS',0);
-/////////////////////////////////////////////////
-// ½ñ¤­¹þ¤ß¤Î²¼¤Ë°ì¹Ô¥³¥á¥ó¥È¤òÆþ¤ì¤ë 1:Æþ¤ì¤ë 0:Æþ¤ì¤Ê¤¤
-define('ARTICLE_COMMENT',1);
-/////////////////////////////////////////////////
-// ²þ¹Ô¤ò¼«Æ°ÅªÊÑ´¹ 1:¤¹¤ë 0:¤·¤Ê¤¤
-define('ARTICLE_AUTO_BR',1);
-
-/////////////////////////////////////////////////
-// Åê¹ÆÆâÍƤΥ᡼¥ë¼«Æ°ÇÛ¿® 1:¤¹¤ë 0:¤·¤Ê¤¤
-define('MAIL_AUTO_SEND',0);
-/////////////////////////////////////////////////
-// Åê¹ÆÆâÍƤΥ᡼¥ëÁ÷¿®»þ¤ÎÁ÷¿®¼Ô¥á¡¼¥ë¥¢¥É¥ì¥¹
-define('MAIL_FROM','');
-/////////////////////////////////////////////////
-// Åê¹ÆÆâÍƤΥ᡼¥ëÁ÷¿®»þ¤ÎÂê̾
-define('MAIL_SUBJECT_PREFIX','[someone\'sPukiWiki]');
-/////////////////////////////////////////////////
+define('PLUGIN_ARTICLE_COLS',  70); // ¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¥«¥é¥à¿ô
+define('PLUGIN_ARTICLE_ROWS',   5); // ¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¹Ô¿ô
+define('PLUGIN_ARTICLE_NAME_COLS',     24); // Ì¾Á°¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¥«¥é¥à¿ô
+define('PLUGIN_ARTICLE_SUBJECT_COLS',  60); // Âê̾¥Æ¥­¥¹¥È¥¨¥ê¥¢¤Î¥«¥é¥à¿ô
+define('PLUGIN_ARTICLE_NAME_FORMAT',   '[[$name]]'); // Ì¾Á°¤ÎÁÞÆþ¥Õ¥©¡¼¥Þ¥Ã¥È
+define('PLUGIN_ARTICLE_SUBJECT_FORMAT',        '**$subject'); // Âê̾¤ÎÁÞÆþ¥Õ¥©¡¼¥Þ¥Ã¥È
+
+define('PLUGIN_ARTICLE_INS',   0); // ÁÞÆþ¤¹¤ë°ÌÃÖ 1:Íó¤ÎÁ° 0:Íó¤Î¸å
+define('PLUGIN_ARTICLE_COMMENT',       1); // ½ñ¤­¹þ¤ß¤Î²¼¤Ë°ì¹Ô¥³¥á¥ó¥È¤òÆþ¤ì¤ë 1:Æþ¤ì¤ë 0:Æþ¤ì¤Ê¤¤
+define('PLUGIN_ARTICLE_AUTO_BR',       1); // ²þ¹Ô¤ò¼«Æ°ÅªÊÑ´¹ 1:¤¹¤ë 0:¤·¤Ê¤¤
+
+define('PLUGIN_ARTICLE_MAIL_AUTO_SEND',        0); // Åê¹ÆÆâÍƤΥ᡼¥ë¼«Æ°ÇÛ¿® 1:¤¹¤ë 0:¤·¤Ê¤¤
+define('PLUGIN_ARTICLE_MAIL_FROM',     ''); // Åê¹ÆÆâÍƤΥ᡼¥ëÁ÷¿®»þ¤ÎÁ÷¿®¼Ô¥á¡¼¥ë¥¢¥É¥ì¥¹
+define('PLUGIN_ARTICLE_MAIL_SUBJECT_PREFIX', "[someone's PukiWiki]"); // Åê¹ÆÆâÍƤΥ᡼¥ëÁ÷¿®»þ¤ÎÂê̾
+
 // Åê¹ÆÆâÍƤΥ᡼¥ë¼«Æ°ÇÛ¿®Àè
-$_mailto = array (
+global $_plugin_article_mailto;
+$_plugin_article_mailto = array (
        ''
 );
 
-function plugin_article_init()
-{
-       if (LANG == 'ja') {
-               $messages = array(
-                       '_btn_name'    => '¤ªÌ¾Á°',
-                       '_btn_article' => 'µ­»ö¤ÎÅê¹Æ',
-                       '_btn_subject' => 'Âê̾: '
-               );
-       }
-       else {
-               $messages = array(
-                       '_btn_name'    => 'Name: ',
-                       '_btn_article' => 'Submit',
-                       '_btn_subject' => 'Subject: '
-               );
-       }
-  set_plugin_messages($messages);
-}
-
 function plugin_article_action()
 {
-       global $script,$post,$vars,$cols,$rows,$now;
-       global $_title_collided,$_msg_collided,$_title_updated;
-       global $_mailto;
-       
-       if ($post['msg'] == '') {
-               return;
-       }
-       
-       $postdata = '';
-       $postdata_old  = get_source($post['refer']);
-       $article_no = 0;
-       
-       if ($post['name'] != '') {
-               $name = str_replace('$name',$post['name'],NAME_FORMAT);
-       }
-       
-       $subject = str_replace('$subject',$post['subject'] == '' ? NO_SUBJECT : $post['subject'],SUBJECT_FORMAT);
-       
-       $article  = "$subject\n>$name ($now)~\n~\n";
-       
+       global $script, $post, $vars, $cols, $rows, $now;
+       global $_title_collided, $_msg_collided, $_title_updated;
+       global $_plugin_article_mailto, $_no_subject, $_no_name;
+
+       if (PKWK_READONLY) die_message('PKWK_READONLY prohibits editing');
+
+       if ($post['msg'] == '')
+               return array('msg'=>'','body'=>'');
+
+       $name = ($post['name'] == '') ? $_no_name : $post['name'];
+       $name = ($name == '') ? '' : str_replace('$name', $name, PLUGIN_ARTICLE_NAME_FORMAT);
+       $subject = ($post['subject'] == '') ? $_no_subject : $post['subject'];
+       $subject = ($subject == '') ? '' : str_replace('$subject', $subject, PLUGIN_ARTICLE_SUBJECT_FORMAT);
+       $article  = $subject . "\n" . '>' . $name . ' (' . $now . ')~' . "\n" . '~' . "\n";
+
        $msg = rtrim($post['msg']);
-       if (ARTICLE_AUTO_BR){
+       if (PLUGIN_ARTICLE_AUTO_BR) {
                //²þ¹Ô¤Î¼è¤ê°·¤¤¤Ï¤±¤Ã¤³¤¦Ìñ²ð¡£ÆäËURL¤¬Íí¤ó¤À¤È¤­¤Ï¡Ä
                //¥³¥á¥ó¥È¹Ô¡¢À°·ÁºÑ¤ß¹Ô¤Ë¤Ï~¤ò¤Ä¤±¤Ê¤¤¤è¤¦¤Ë arino
-               $msg = join("\n",preg_replace('/^(?!\/\/)(?!\s)(.*)$/','$1~',explode("\n",$msg)));
-       }
-       $article .= $msg;
-       $article .= "\n<";
-       
-       if (ARTICLE_COMMENT) {
-               $article .= "\n\n#comment\n";
+               $msg = join("\n", preg_replace('/^(?!\/\/)(?!\s)(.*)$/', '$1~', explode("\n", $msg)));
        }
-       
+       $article .= $msg . "\n\n" . '//';
+
+       if (PLUGIN_ARTICLE_COMMENT) $article .= "\n\n" . '#comment' . "\n";
+
+       $postdata = '';
+       $postdata_old  = get_source($post['refer']);
+       $article_no = 0;
+
        foreach($postdata_old as $line) {
-               if (!ARTICLE_INS) {
-                       $postdata .= $line;
-               }
-               if (preg_match('/^#article/',$line)) {
-                       if ($article_no == $post['article_no'] && $post['msg'] != '') {
-                               $postdata .= "$article\n";
-                       }
+               if (! PLUGIN_ARTICLE_INS) $postdata .= $line;
+               if (preg_match('/^#article/i', $line)) {
+                       if ($article_no == $post['article_no'] && $post['msg'] != '')
+                               $postdata .= $article . "\n";
                        $article_no++;
                }
-               if (ARTICLE_INS) {
-                       $postdata .= $line;
-               }
+               if (PLUGIN_ARTICLE_INS) $postdata .= $line;
        }
-       
-       $postdata_input = "$article\n";
+
+       $postdata_input = $article . "\n";
        $body = '';
-       
-       if (md5(@join('',get_source($post['refer']))) != $post['digest']) {
+
+       if (md5(@join('', get_source($post['refer']))) != $post['digest']) {
                $title = $_title_collided;
-               
-               $body = "$_msg_collided\n";
-               
-               $s_refer = htmlspecialchars($post['refer']);
-               $s_digest = htmlspecialchars($post['digest']);
+
+               $body = $_msg_collided . "\n";
+
+               $s_refer    = htmlspecialchars($post['refer']);
+               $s_digest   = htmlspecialchars($post['digest']);
                $s_postdata = htmlspecialchars($postdata_input);
                $body .= <<<EOD
 <form action="$script?cmd=preview" method="post">
@@ -160,59 +104,59 @@ function plugin_article_action()
  </div>
 </form>
 EOD;
-       }
-       else {
-               page_write($post['refer'],trim($postdata));
-               
+
+       else {
+               page_write($post['refer'], trim($postdata));
+
                // Åê¹ÆÆâÍƤΥ᡼¥ë¼«Æ°Á÷¿®
-               if (MAIL_AUTO_SEND) {
-                       $mailaddress = implode(',' ,$_mailto);
-                       $mailsubject = MAIL_SUBJECT_PREFIX.' '.str_replace('**','',$subject);
-                       if ($post['name']) {
-                               $mailsubject .= '/'.$post['name'];
-                       }
+               if (PLUGIN_ARTICLE_MAIL_AUTO_SEND) {
+                       $mailaddress = implode(',', $_plugin_article_mailto);
+                       $mailsubject = PLUGIN_ARTICLE_MAIL_SUBJECT_PREFIX . ' ' . str_replace('**', '', $subject);
+                       if ($post['name'])
+                               $mailsubject .= '/' . $post['name'];
                        $mailsubject = mb_encode_mimeheader($mailsubject);
-                       
+
                        $mailbody = $post['msg'];
-                       $mailbody .= "\n\n---\n";
-                       $mailbody .= "Åê¹Æ¼Ô: ".$post['name']." ($now)\n";
-                       $mailbody .= "Åê¹ÆÀè: ".$post['refer']."\n";
-                       $mailbody .= "¡¡ URL: ".$script.'?'.rawurlencode($post['refer'])."\n";
-                       $mailbody = mb_convert_encoding( $mailbody, "JIS" );
-                       
-                       $mailaddheader = "From: ".MAIL_FROM;
-                       
+                       $mailbody .= "\n\n" . '---' . "\n";
+                       $mailbody .= $_msg_article_mail_sender . $post['name'] . ' (' . $now . ')' . "\n";
+                       $mailbody .= $_msg_article_mail_page . $post['refer'] . "\n";
+                       $mailbody .= '¡¡ URL: ' . $script . '?' . rawurlencode($post['refer']) . "\n";
+                       $mailbody = mb_convert_encoding($mailbody, 'JIS');
+
+                       $mailaddheader = 'From: ' . PLUGIN_ARTICLE_MAIL_FROM;
+
                        mail($mailaddress, $mailsubject, $mailbody, $mailaddheader);
                }
-               
+
                $title = $_title_updated;
        }
        $retvars['msg'] = $title;
        $retvars['body'] = $body;
-       
+
        $post['page'] = $post['refer'];
        $vars['page'] = $post['refer'];
-       
+
        return $retvars;
 }
+
 function plugin_article_convert()
 {
-       global $script,$vars,$digest;
-       global $_btn_article,$_btn_name,$_btn_subject;
+       global $script, $vars, $digest;
+       global $_btn_article, $_btn_name, $_btn_subject;
        static $numbers = array();
-       
-       if (!array_key_exists($vars['page'],$numbers))
-       {
-               $numbers[$vars['page']] = 0;
-       }
+
+       if (PKWK_READONLY) return ''; // Show nothing
+
+       if (! isset($numbers[$vars['page']])) $numbers[$vars['page']] = 0;
+
        $article_no = $numbers[$vars['page']]++;
-       
-       $s_page = htmlspecialchars($vars['page']);
+
+       $s_page   = htmlspecialchars($vars['page']);
        $s_digest = htmlspecialchars($digest);
-       $name_cols = NAME_COLS;
-       $subject_cols = SUBJECT_COLS;
-       $article_rows = article_ROWS;
-       $article_cols = article_COLS;
+       $name_cols = PLUGIN_ARTICLE_NAME_COLS;
+       $subject_cols = PLUGIN_ARTICLE_SUBJECT_COLS;
+       $article_rows = PLUGIN_ARTICLE_ROWS;
+       $article_cols = PLUGIN_ARTICLE_COLS;
        $string = <<<EOD
 <form action="$script" method="post">
  <div>
@@ -227,7 +171,7 @@ function plugin_article_convert()
  </div>
 </form>
 EOD;
-       
+
        return $string;
 }
 ?>