X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=banana%2Fbanana.inc.php.in;h=9989956de6d5c8dea29fe0eb16bcb98f755d8c1e;hb=aef14768eb767ed4a3801bdd9cfe719c2f615593;hp=bb8475d62cdfc234f2ac5d3214ff3214943eb195;hpb=78cd27b3ec8300e0a8ed7e6b909e3ea99fa75911;p=banana.git diff --git a/banana/banana.inc.php.in b/banana/banana.inc.php.in index bb8475d..9989956 100644 --- a/banana/banana.inc.php.in +++ b/banana/banana.inc.php.in @@ -9,28 +9,40 @@ class Banana { - var $maxspool = 3000; + var $maxspool = 3000; + var $maxfilesize = 100000; - var $hdecode = array('from','name','organization','subject'); - var $parse_hdr = array('content-transfer-encoding', 'content-type', 'date', 'followup-to', 'from', + var $hdecode = array('from','name','organization','subject'); + var $parse_hdr = array('content-disposition', 'content-transfer-encoding', 'content-type', 'date', 'followup-to', 'from', 'message-id', 'newsgroups', 'organization', 'references', 'subject', 'x-face'); - var $show_hdr = array('from', 'subject', 'newsgroups', 'followup', 'date', 'organization', 'references', 'x-face'); + var $show_hdr = array('from', 'subject', 'newsgroups', 'followup', 'date', 'organization', 'references', 'x-face'); + /** Favorites MIMEtypes to use, by order for reading multipart messages + */ + var $body_mime = array('text/plain', 'text/html', 'text/richtext'); - var $tbefore = 5; - var $tafter = 5; - var $tmax = 50; + /** Regexp for selecting newsgroups to show (if empty, match all newsgroups) + * ex : '^xorg\..*' for xorg.* + */ + var $grp_pattern; - var $wrap = 74; + var $tbefore = 5; + var $tafter = 5; + var $tmax = 50; - var $custom = "Content-Type: text/plain; charset=utf-8\nMime-Version: 1.0\nContent-Transfer-Encoding: 8bit\nUser-Agent: Banana @VERSION@\n"; + var $wrap = 74; - var $host = 'news://localhost:119/'; + var $boundary = "bananaBoundary42"; + var $custom = "Content-Type: text/plain; charset=utf-8\nMime-Version: 1.0\nContent-Transfer-Encoding: 8bit\nUser-Agent: Banana @VERSION@\n"; + var $custom_mp = "Content-Type: multipart/mixed; boundary=\"bananaBoundary42\"\nContent-Transfer-Encoding: 7bit\nUser-Agent: Banana @VERSION@\n"; + var $custom_bd = "Content-Type: text/plain; charset=utf-8\nContent-Transfert-Encoding: 8bit"; - var $profile = Array( 'name' => 'Anonymous ', 'sig' => '', 'org' => '', + var $host = 'news://localhost:119/'; + + var $profile = Array( 'name' => 'Anonymous ', 'sig' => '', 'org' => '', 'customhdr' =>'', 'display' => 0, 'lastnews' => 0, 'locale' => 'fr_FR', 'subscribe' => array()); - var $state = Array('group' => null, 'artid' => null); + var $state = Array('group' => null, 'artid' => null); var $nntp; var $groups; var $newgroups; @@ -47,6 +59,7 @@ class Banana function run($class = 'Banana') { global $banana; + Banana::_require('misc'); $banana = new $class(); @@ -56,6 +69,7 @@ class Banana $group = empty($_GET['group']) ? null : strtolower($_GET['group']); $artid = empty($_GET['artid']) ? null : strtolower($_GET['artid']); + $partid = !isset($_GET['part']) ? -1 : $_GET['part']; $banana->state = Array ('group' => $group, 'artid' => $artid); if (is_null($group)) { @@ -68,7 +82,6 @@ class Banana return $banana->action_listGroups(); } elseif (is_null($artid)) { - if (isset($_POST['action']) && $_POST['action'] == 'new') { return $banana->action_doFup($group, isset($_POST['artid']) ? intval($_POST['artid']) : -1); } elseif (isset($_GET['action']) && $_GET['action'] == 'new') { @@ -88,7 +101,7 @@ class Banana if (isset($_GET['action'])) { switch ($_GET['action']) { case 'cancel': - $res .= $banana->action_showArticle($group, $artid); + $res .= $banana->action_showArticle($group, $artid, $partid); if ($banana->post->checkcancel()) { $form = '

'._b_('Voulez-vous vraiment annuler ce message ?').'

' . "

" @@ -103,7 +116,16 @@ class Banana return $banana->action_newFup($group, $artid); } } - return $res . $banana->action_showArticle($group, $artid); + + if (isset($_GET['pj'])) { + $action = false; + if (isset($_GET['action']) && $_GET['action'] == 'view') { + $action = true; + } + return $banana->action_getAttachment($group, $artid, $_GET['pj'], $action); + } + + return $res . $banana->action_showArticle($group, $artid, $partid); } } @@ -163,7 +185,7 @@ class Banana return $res.$cuts; } - function action_showArticle($group, $id) + function action_showArticle($group, $id, $part) { $this->_newSpool($group, $this->profile['display'], $this->profile['lastnews']); $this->_newPost($id); @@ -177,13 +199,33 @@ class Banana $cuts = displayshortcuts(); $res = '

'._b_('Message').'

'.$cuts; - $res .= $this->post->to_html(); + $res .= $this->post->to_html($part); $this->nntp->quit(); return $res.$cuts; } + function action_getAttachment($group, $id, $pjid, $action) + { + $this->_newSpool($group, $this->profile['display'], $this->profile['lastnews']); + $this->_newPost($id); + if (!$this->post) { + if ($this->nntp->lasterrorcode == "423") { + $this->spool->delid($id); + } + $this->nntp->quit(); + return displayshortcuts().'

'._b_('Impossible d\'accéder au message. Le message a peut-être été annulé').'

'; + } + + $this->nntp->quit(); + if ($this->post->get_attachment($pjid, $action)) { + return ""; + } else { + return displayshortcuts().'

'._b_('Impossible d\'accéder à la pièce jointe.').'

'; + } + } + function action_cancelArticle($group, $id) { $this->_newSpool($group, $this->profile['display'], $this->profile['lastnews']); @@ -219,7 +261,7 @@ class Banana $this->_newPost($id); if ($this->post) { $subject = preg_replace("/^re\s*:\s*/i", '', 'Re: '.$this->post->headers['subject']); - $body = utf8_encode($this->post->name." "._b_("a écrit"))." :\n".wrap($this->post->body, "> "); + $body = utf8_encode($this->post->name." "._b_("a écrit"))." :\n".wrap($this->post->get_body(), "> "); $target = isset($this->post->headers['followup-to']) ? $this->post->headers['followup-to'] : $this->post->headers['newsgroups']; } } @@ -228,7 +270,7 @@ class Banana $cuts = displayshortcuts(); $html = '

'._b_('Nouveau message').'

'.$cuts; - $html .= ''; + $html .= ''; $html .= ''; $html .= ''; $html .= ''; @@ -238,13 +280,16 @@ class Banana $html .= ''; $html .= ''; $html .= ''; - $html .= ''; + $html .= ''; + $html .= ''; + $html .= ''; + $html .= ''; $html .= '
'._b_('En-têtes').'
'._b_('Nom').''.htmlentities($this->profile['name']).'
'._b_('Organisation').''.$this->profile['org'].'
'._b_('Corps').'
'; + .to_entities($body).($this->profile['sig'] ? "\n\n-- \n".htmlentities($this->profile['sig']) : '').'
'._b_('Pièces jointes').'
'; + $html .= '
'; if ($id > 0) { $html .= ''; } $html .= ''; - $html .= '
'; return $html.$cuts; @@ -275,7 +320,24 @@ class Banana $msg .= "References: $refs{$post->headers['message-id']}\n"; } - $msg .= $this->custom.$this->profile['customhdr']."\n".wrap($body, "", $this->wrap); + $body = wrap($body, "", $this->wrap); + + // include attachment in the body + $uploaded = $this->_upload('newpj'); + if ($uploaded['error'] == 0) { + $this->custom = $this->custom_mp; + $body = "\n--".$this->boundary."\n".$this->custom_bd."\n\n".$body."\n--".$this->boundary."\n"; + + $body .= 'Content-Type: '.$uploaded['type'].'; name="'.$uploaded['name']."\"\n"; + $body .= 'Content-Transfer-Encoding: '.$uploaded['encoding']."\n\n"; + $body .= 'Content-Disposition: attachment; filename="'.$uploaded['name']."\"\n"; + $body .= $uploaded['data']; + $body .= '--'.$this->boundary.'--'; + } + #TODO:afficher les erreurs lorsque l'upload ne marche pas + + // finalise and post the message + $msg .= $this->custom.$this->profile['customhdr']."\n".$body; if ($this->nntp->post($msg)) { header("Location: ?group=$group".($artid==-1 ? '' : "&first=$artid")); @@ -314,6 +376,43 @@ class Banana { require_once (dirname(__FILE__).'/'.$file.'.inc.php'); } + + function _upload($file) + { + if ($_FILES[$file]['name'] == "") { + return Array( 'error' => -1 ); + } + + // upload + $_FILES[$file]['tmp_name']; + + // test if upload is ok + $file = $_FILES[$file]; + if ($file['size'] == 0 || $file['error'] != 0) { + if ($file['error'] == 0) { + $file['error'] = -1; + } + return $file; + } + + // adding custum data + $mime = rtrim(shell_exec('file -bi '.$file['tmp_name'])); //Because mime_content_type don't work :( + $encod = 'base64'; + if (preg_match("@([^ ]+/[^ ]+); (.*)@", $mime, $format)) { + $mime = $format[1]; + $encod = $format[2]; + } + $data = fread(fopen($file['tmp_name'], 'r'), $file['size']); + if ($encod == 'base64') { + $data = chunk_split(base64_encode($data)); + } + $file['name'] = basename($file['name']); + $file['type'] = $mime; + $file['encoding'] = $encod; + $file['data'] = $data; + + return $file; + } } ?>