Hi, this is graf25, and I'm an idiot. :)
[squirrelmail.git] / functions / imap_search.php
index d22f80dcf4ccadb092cb8399c4b72b6f3cab7908..fa2b6a95e6fbbcd280991bc12c9e0f6d93c8eb49 100644 (file)
 <?php
 
-   /**
-    *   imap_search.php
-    *
-    *   Copyright (c) 1999-2001 The Squirrelmail Development Team
-    *   Licensed under the GNU GPL. For full terms see the file COPYING.
-    *
-    *   IMAP search routines
-    *
-    *  $Id$
-    */
-
-
-    require_once('../functions/imap.php');
-    require_once('../functions/date.php');
-    require_once('../functions/array.php');
-    require_once('../functions/mailbox_display.php');
-    require_once('../functions/mime.php');
-
-
-    function sqimap_search($imapConnection,$search_where,$search_what,$mailbox,$color) {
-
-        global $msgs, $message_highlight_list, $squirrelmail_language, $languages, $index_order;
-
-        $urlMailbox = urlencode($mailbox);
-        $isid = sqimap_session_id();
-
-        /* Construct the Search QuERY */
-        $ss = $isid;
-        if (isset($languages[$squirrelmail_language]['CHARSET']) &&
-            $languages[$squirrelmail_language]['CHARSET']) {
-            $ss .= " SEARCH CHARSET ".$languages[$squirrelmail_language]['CHARSET']." ALL $search_where \"$search_what\"\r\n";
-        } else {
-            $ss .= " SEARCH ALL $search_where \"$search_what\"\r\n";
+/**
+ * imap_search.php
+ *
+ * Copyright (c) 1999-2002 The SquirrelMail Project Team
+ * Licensed under the GNU GPL. For full terms see the file COPYING.
+ *
+ * IMAP search routines
+ *
+ * $Id$
+ */
+
+require_once('../functions/imap.php');
+require_once('../functions/date.php');
+require_once('../functions/array.php');
+require_once('../functions/mailbox_display.php');
+require_once('../functions/mime.php');
+
+function sqimap_search($imapConnection, $search_where, $search_what, $mailbox,
+                       $color, $search_position = '', $search_all, $count_all) {
+
+    global $msgs, $message_highlight_list, $squirrelmail_language, $languages,
+           $index_order, $pos, $allow_charset_search, $imap_server_type;
+    $pos = $search_position;
+
+    $urlMailbox = urlencode($mailbox);
+
+    /* construct the search query, taking multiple search terms into account */
+    $multi_search = array();
+    $search_what  = trim($search_what);
+    $search_what  = ereg_replace('[ ]{2,}', ' ', $search_what);
+    $multi_search = explode(' ', $search_what);
+    $search_string = '';
+
+    /* it seems macosx does not support the prefered search 
+       syntax so we fall back to the older style. This IMAP
+       server has a problem with multiple search terms. Instead
+       of returning the messages that match all the terms it
+       returns the messages that match each term. Could be fixed
+       on the client side, but should be fixed on the server
+       as per the RFC */
+       
+    if ($imap_server_type == 'macosx') {
+        foreach ($multi_search as $multi_search_part) {
+            $search_string .= $search_where . ' ' .$multi_search_part. ' ';
         }
-        fputs($imapConnection,$ss);
-
-        # Read Data Back From IMAP
-        $readin = sqimap_read_data ($imapConnection, $isid, false, $result, $message);
-        if (isset($languages[$squirrelmail_language]['CHARSET']) && strtolower($result) == 'no') {
-            $ss = $isid . " SEARCH CHARSET \"US-ASCII\" ALL $search_where \"$search_what\"\r\n";
-            fputs ($imapConnection, $ss);
-            $readin = sqimap_read_data ($imapConnection, $isid, true, $result, $message);
+    }
+    else {
+        foreach ($multi_search as $multi_search_part) {
+            $search_string .= $search_where . ' {' . strlen($multi_search_part)
+                . "}\r\n" . $multi_search_part . ' ';
         }
+    }
+    
+    $search_string = trim($search_string);
+
+    /* now use $search_string in the imap search */
+    if ($allow_charset_search && isset($languages[$squirrelmail_language]['CHARSET']) &&
+        $languages[$squirrelmail_language]['CHARSET']) {
+        $ss = "SEARCH CHARSET "
+            . strtoupper($languages[$squirrelmail_language]['CHARSET']) 
+            . " ALL $search_string";
+    } else {
+        $ss = "SEARCH ALL $search_string";
+    }
 
-        unset($messagelist); $msgs=""; $c = 0;
+    /* read data back from IMAP */
+    $readin = sqimap_run_command($imapConnection, $ss, false, $result, $message);
 
-        /* Keep going till we find the SEARCH responce */
-        while ($c < count( $readin )) {
+    /* try US-ASCII charset if search fails */
+    if (isset($languages[$squirrelmail_language]['CHARSET']) 
+        && strtolower($result) == 'no') {
+        $ss = "SEARCH CHARSET \"US-ASCII\" ALL $search_string";
+        $readin = sqimap_run_command ($imapConnection, $ss, true, 
+                                      $result, $message);
+    }
 
-            /* Check to see if a SEARCH Responce was recived */
-            if (substr($readin[$c],0,9) == "* SEARCH ")
-                $messagelist = explode(" ",substr($readin[$c],9));
-            else if (isset($errors))
-                $errors = $errors.$readin[$c];
-            else
-                $errors = $readin[$c];
-            $c++;
-        }
+    unset($messagelist);
+    $msgs = '';
 
-        #If nothing is found * SEARCH should be the first error else echo errors
-        if (isset($errors) && strstr($errors,"* SEARCH")) {
-            echo '<br><CENTER>' . _("No Messages Found") . '</CENTER>';
-            return;
+    /* Keep going till we find the SEARCH response */
+    foreach ($readin as $readin_part) {
+        /* Check to see if a SEARCH response was received */
+        if (substr($readin_part, 0, 9) == '* SEARCH ') {
+            $messagelist = explode(' ', substr($readin_part, 9));
         } else if (isset($errors)) {
-            echo "<!-- ".$errors." -->";
+            $errors = $errors.$readin_part;
+        } else {
+            $errors = $readin_part;
         }
+    }
 
-        # HACKED CODED FROM ANOTHER FUNCTION, Could Probably dump this and mondify
-        # exsitising code with a search true/false varible.
+    /* If nothing is found * SEARCH should be the first error else echo errors */
+    if (isset($errors)) {
+        if (strstr($errors,'* SEARCH')) {
+            if ($search_all != 'all') {
+                echo '<br><CENTER>' . _("No Messages Found") . '</CENTER>';
+            }
+            return;
+        }
+        echo "<!-- $errors -->";
+    }
 
+    /*
+     * HACKED CODE FROM ANOTHER FUNCTION, could probably dump this and modify
+     * existing code with a search true/false variable.
+     */
 
-        global $sent_folder;
-        for ($q = 0; $q < count($messagelist); $q++) {
-            $id[$q] = trim($messagelist[$q]);
-        }
-        $issent = ($mailbox == $sent_folder);
-        $hdr_list = sqimap_get_small_header_list($imapConnection, $id, $issent);
-        $flags = sqimap_get_flags_list($imapConnection, $id, $issent);
-        foreach ($hdr_list as $hdr) {
-            $from[] = $hdr->from;
-            $date[] = $hdr->date;
-            $subject[] = $hdr->subject;
-            $to[] = $hdr->to;
-            $priority[] = $hdr->priority;
-            $cc[] = $hdr->cc;
-            $size[] = $hdr->size;
-            $type[] = $hdr->type0;
-        }
+    global $sent_folder;
+    for ($q = 0; $q < count($messagelist); $q++) {
+        $id[$q] = trim($messagelist[$q]);
+    }
+    $issent = ($mailbox == $sent_folder);
+    $hdr_list = sqimap_get_small_header_list($imapConnection, $id, $issent);
+//    $flags = sqimap_get_flags_list($imapConnection, $id, $issent);
+
+    foreach ($hdr_list as $hdr) {
+        $from[] = $hdr->from;
+        $date[] = $hdr->date;
+        $subject[] = $hdr->subject;
+        $to[] = $hdr->to;
+        $priority[] = $hdr->priority;
+        $cc[] = $hdr->cc;
+        $size[] = $hdr->size;
+        $type[] = $hdr->type0;
+       $flag_deleted[] = $hdr->flag_deleted;
+       $flag_answered[] = $hdr->flag_answered;
+       $flag_seen[] = $hdr->flag_seen;
+       $flag_flagged[] = $hdr->flag_flagged;
+    }
 
-        $j = 0;
-        while ($j < count($messagelist)) {
-                $date[$j] = ereg_replace('  ', ' ', $date[$j]);
-                $tmpdate = explode(" ", trim($date[$j]));
-
-                $messages[$j]["TIME_STAMP"] = getTimeStamp($tmpdate);
-                $messages[$j]["DATE_STRING"] = getDateString($messages[$j]["TIME_STAMP"]);
-                $messages[$j]["ID"] = $id[$j];
-                $messages[$j]["FROM"] = decodeHeader($from[$j]);
-                $messages[$j]["FROM-SORT"] = strtolower(sqimap_find_displayable_name(decodeHeader($from[$j])));
-                $messages[$j]["SUBJECT"] = decodeHeader($subject[$j]);
-                $messages[$j]["SUBJECT-SORT"] = strtolower(decodeHeader($subject[$j]));
-                $messages[$j]["TO"] = decodeHeader($to[$j]);
-                $messages[$j]["PRIORITY"] = $priority[$j];
-                $messages[$j]["CC"] = $cc[$j];
-                $messages[$j]["SIZE"] = $size[$j];
-                $messages[$j]["TYPE0"] = $type[$j];
-
-                $num = 0;
-                while ($num < count($flags[$j])) {
-                    if ($flags[$j][$num] == 'Deleted') {
-                        $messages[$j]['FLAG_DELETED'] = true;
-                    } else if ($flags[$j][$num] == 'Answered') {
-                        $messages[$j]['FLAG_ANSWERED'] = true;
-                    } else if ($flags[$j][$num] == 'Seen') {
-                        $messages[$j]['FLAG_SEEN'] = true;
-                    } else if ($flags[$j][$num] == 'Flagged') {
-                        $messages[$j]['FLAG_FLAGGED'] = true;
-                    }
-                    $num++;
+    $j = 0;
+    while ($j < count($messagelist)) {
+            $date[$j] = str_replace('  ', ' ', $date[$j]);
+            $tmpdate = explode(' ', trim($date[$j]));
+
+            $messages[$j]["TIME_STAMP"] = getTimeStamp($tmpdate);
+            $messages[$j]["DATE_STRING"] = getDateString($messages[$j]["TIME_STAMP"]);
+            $messages[$j]["ID"] = $id[$j];
+            $messages[$j]["FROM"] = decodeHeader($from[$j]);
+            $messages[$j]["FROM-SORT"] = strtolower(sqimap_find_displayable_name(decodeHeader($from[$j])));
+            $messages[$j]["SUBJECT"] = decodeHeader($subject[$j]);
+            $messages[$j]["SUBJECT-SORT"] = strtolower(decodeHeader($subject[$j]));
+            $messages[$j]["TO"] = decodeHeader($to[$j]);
+            $messages[$j]["PRIORITY"] = $priority[$j];
+            $messages[$j]["CC"] = $cc[$j];
+            $messages[$j]["SIZE"] = $size[$j];
+            $messages[$j]["TYPE0"] = $type[$j];
+           $messages[$j]['FLAG_DELETED'] = $flag_deleted[$j];
+            $messages[$j]['FLAG_ANSWERED'] = $flag_answered[$j];
+            $messages[$j]['FLAG_SEEN'] = $flag_seen[$j];
+            $messages[$j]['FLAG_FLAGGED'] = $flag_flagged[$j];
+/*
+            $num = 0;
+            while ($num < count($flags[$j])) {
+                if ($flags[$j][$num] == 'Deleted') {
+                    $messages[$j]['FLAG_DELETED'] = true;
+                } else if ($flags[$j][$num] == 'Answered') {
+                    $messages[$j]['FLAG_ANSWERED'] = true;
+                } else if ($flags[$j][$num] == 'Seen') {
+                    $messages[$j]['FLAG_SEEN'] = true;
+                } else if ($flags[$j][$num] == 'Flagged') {
+                    $messages[$j]['FLAG_FLAGGED'] = true;
                 }
-                $j++;
-        }
-
-        /** Find and remove the ones that are deleted */
-        $i = 0;
-        $j = 0;
-        while ($j < count($messagelist)) {
-            if (isset($messages[$j]["FLAG_DELETED"]) && $messages[$j]["FLAG_DELETED"] == true) {
-                $j++;
-                continue;
+                $num++;
             }
-            $msgs[$i] = $messages[$j];
+*/         
+            $j++;
+
+    }
 
-            $i++;
+    /* Find and remove the ones that are deleted */
+    $i = 0;
+    $j = 0;
+    while ($j < count($messagelist)) {
+        if (isset($messages[$j]['FLAG_DELETED']) && $messages[$j]['FLAG_DELETED']) {
             $j++;
+            continue;
         }
-        $numMessages = $i;
+        $msgs[$i] = $messages[$j];
 
-        // There's gotta be messages in the array for it to sort them.
-
-        if (count($messagelist) > 0) {
-            $j=0;
-            if (!isset ($msg)) { $msg = ""; }
-            mail_message_listing_beginning($imapConnection,
-                "move_messages.php?msg=$msg&mailbox=$urlMailbox&where=".urlencode($search_where)."&what=".urlencode($search_what),
-                $mailbox, -1, '<b>' . _("Found") . ' ' . count($messagelist) . ' ' . _("messages") . '</b>',
-                '&nbsp;');
+        $i++;
+        $j++;
+    }
+    $numMessages = $i;
 
+    /* There's gotta be messages in the array for it to sort them. */
 
-            while ($j < count($msgs)) {
-                printMessageInfo($imapConnection, $msgs[$j]["ID"], 0, $j, $mailbox, "", 0, $search_where, $search_what);
-                $j++;
+    if (count($messagelist) > 0) {
+        $j=0;
+        if (!isset ($msg)) {
+            $msg = '';
+        }
+        if ($search_all != 'all') {
+            if ( !isset( $start_msg ) ) {
+                $start_msg =0;
             }
-            echo '</table></tr></td></table>';
+            if ( !isset( $sort ) ) {
+                    $sort = 0;
+            }
+            mail_message_listing_beginning( $imapConnection,
+                "move_messages.php?msg=$msg&mailbox=$urlMailbox&pos=$pos&where=" . urlencode($search_where) . "&what=".urlencode($search_what),
+                $mailbox,
+                -1,
+                '<b>' . _("Found") . ' ' . count($messagelist) . ' ' . _("messages") . '</b></tr><tr>'.
+                get_selectall_link($start_msg, $sort));
+        }
+        else {
+            mail_message_listing_beginning( $imapConnection,
+                "move_messages.php?msg=$msg&mailbox=$urlMailbox&pos=$pos&where=" . urlencode($search_where) . "&what=".urlencode($search_what),
+                $mailbox,
+                -1,
+                '<b>' . _("Found") . ' ' . count($messagelist) . ' ' . _("messages") . '</b></tr><tr>');
+        }
+        if ( $mailbox == 'INBOX' ) {
+            $showbox = _("INBOX");
+        } else {
+            $showbox = $mailbox;
+        }
+        echo '<b><big>' . _("Folder:") . " $showbox</big></b>";
+        while ($j < count($msgs)) {
+            printMessageInfo($imapConnection, $msgs[$j]["ID"], 0, $j, $mailbox, '', 0, $search_where, $search_what);
+            $j++;
+            echo '</td></tr>';
         }
+        echo '</table></td></tr></table></form>';
+        $count_all = count($msgs);
     }
+    return $count_all;
+}
 
-?>
\ No newline at end of file
+?>