X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Fimap_search.php;h=4190597ffca77b500273a3a7bb96ab5939fb211f;hp=6180c46732e0988c09246638d85115cb3757af6c;hb=15e6162eacc97158393bc75aed3afeb7b19c24a6;hpb=180aa6d7967f215ec4f3ba2e4658d02c08a5f53c diff --git a/functions/imap_search.php b/functions/imap_search.php index 6180c467..4190597f 100644 --- a/functions/imap_search.php +++ b/functions/imap_search.php @@ -1,155 +1,162 @@ -
No Messages Found
"; - return; - } else if (isset($errors)) { - echo ""; - } - - # HACKED CODED FROM ANOTHER FUNCTION, Could Probably dump this and mondify - # exsitising code with a search true/false varible. - - - 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; - } - - $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; + + 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"; + } + 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); + } + + unset($messagelist); $msgs=""; $c = 0; + + /* Keep going till we find the SEARCH responce */ + while ($c < count( $readin )) { + + /* 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++; + } + + /* If nothing is found * SEARCH should be the first error else echo errors */ + if (isset($errors) && strstr($errors,"* SEARCH")) { + echo '
' . _("No Messages Found") . '
'; + return; + } else if (isset($errors)) { + echo ""; + } + + /* + HACKED CODED FROM ANOTHER FUNCTION, Could Probably dump this and mondify + exsitising code with a search true/false varible. + */ + + 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; + } + + $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++; } - $num++; - } - $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++; + } + + /* 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; - } - $msgs[$i] = $messages[$j]; - - $i++; - $j++; - } - $numMessages = $i; - - // 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), - '', -1, '' . _("Found") . ' ' . count($messagelist) . ' ' . _("messages") . '', - ' '); - - - while ($j < count($msgs)) { - printMessageInfo($imapConnection, $msgs[$j]["ID"], 0, $j, $mailbox, "", 0, $search_where, $search_what); + } + $msgs[$i] = $messages[$j]; + + $i++; + $j++; + } + $numMessages = $i; + + /* 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, + '' . _("Found") . ' ' . count($messagelist) . ' ' . _("messages") . '', + get_selectall_link($start_msg, $sort) ); + + + while ($j < count($msgs)) { + printMessageInfo($imapConnection, $msgs[$j]["ID"], 0, $j, $mailbox, '', 0, $search_where, $search_what); $j++; - } - echo ""; - echo ""; - } - } + } + echo ''; + } +} -?> \ No newline at end of file +?>