6 * Copyright (c) 1999-2002 The SquirrelMail Project Team
7 * Licensed under the GNU GPL. For full terms see the file COPYING.
9 * Implementation of RFC 2369 for SquirrelMail.
10 * When viewing a message from a mailinglist complying with this RFC,
11 * this plugin displays a menu which gives the user a choice of mailinglist
12 * commands such as (un)subscribe, help and list archives.
17 function squirrelmail_plugin_init_listcommands () {
18 global $squirrelmail_plugin_hooks;
20 $squirrelmail_plugin_hooks['read_body_header']['listcommands'] = 'plugin_listcommands_menu';
23 function plugin_listcommands_menu() {
24 global $imapConnection, $passed_id, $color, $mailbox,
25 $subject, $ent_num, $priority_level, $compose_new_win;
28 * Array of commands we can deal with from the header. The Reply option
29 * is added later because we generate it using the Post information.
31 $fieldsdescr = array('Post' => _("Post to List"),
32 'Reply' => _("Reply to List"),
33 'Subscribe' => _("Subscribe"),
34 'Unsubscribe' => _("Unsubscribe"),
35 'Archive' => _("List Archives"),
36 'Owner' => _("Contact Listowner"),
38 $fields = array_keys($fieldsdescr);
40 $sorted_cmds = array();
41 $unsorted_cmds = array();
44 $lfields = 'List-' . implode (' List-', $fields);
46 $sid = sqimap_session_id();
47 fputs ($imapConnection, "$sid FETCH $passed_id BODY.PEEK[HEADER.FIELDS ($lfields)]\r\n");
48 $read = sqimap_read_data($imapConnection, $sid, true, $response, $emessage);
50 for ($i = 1; $i < count($read); $i++
) {
51 foreach ($fields as $field) {
52 if ( preg_match("/^List-$field: *<(.+?)>/i", $read[$i], $match) ) {
53 $unsorted_cmds[$field] = $match[1];
58 if (count($unsorted_cmds) == 0) {
62 foreach ($fields as $field) {
63 foreach ($unsorted_cmds as $cmd => $url) {
70 foreach ($cmds as $cmd => $url) {
71 if (eregi('mailto:(.+)', $url, $regs)) {
72 $purl = parse_url($url);
74 if (($cmd == 'Post') ||
($cmd == 'Owner')) {
75 $url = 'compose.php?';
77 $url = "../plugins/listcommands/mailout.php?action=$cmd&";
80 $url .= 'mailbox=' . urlencode($mailbox)
81 . '&send_to=' . $purl['path'];
83 if (isset($purl['query'])) {
84 $url .= '&' . $purl['query'];
86 if ($compose_new_win == '1') {
87 $output[] = '<A HREF="' . $url . '" target="compose_window" onClick="comp_in_new()">' . $fieldsdescr[$cmd] . '</A>';
90 $output[] = '<A HREF="' . $url . '">' . $fieldsdescr[$cmd] . '</A>';
93 $url .= '&reply_subj=' . urlencode($subject)
94 . '&reply_id=' . $passed_id
95 . '&ent_num=' . $ent_num
96 . '&mailprio=' . $priority_level;
97 if ($compose_new_win == '1') {
98 $output[] = '<A HREF="' . $url . '" target="compose_window" onClick="comp_in_new()">' . $fieldsdescr['Reply'] . '</A>';
101 $output[] = '<A HREF="' . $url . '">' . $fieldsdescr['Reply'] . '</A>';
104 } else if (eregi('^(http|ftp)', $url)) {
105 $output[] = '<A HREF="' . $url . '" TARGET="_blank">'
106 . $fieldsdescr[$cmd] . '</A>';
110 if (count($output) > 0) {
112 echo "<td ALIGN=RIGHT BGCOLOR=\"$color[0]\">"
113 . str_replace(' ', ' ', _("Mailing List:"))
115 echo "<td BGCOLOR=\"$color[0]\" WIDTH=\"100%\" colspan=\"2\">"
116 . '<SMALL>' . implode(' | ', $output) . '</SMALL>'