summaryrefslogtreecommitdiff
path: root/program
diff options
context:
space:
mode:
authorthomascube <thomas@roundcube.net>2006-03-24 17:08:37 +0000
committerthomascube <thomas@roundcube.net>2006-03-24 17:08:37 +0000
commit95c2c3ce977fc9962c544daed93f155b6b1c8069 (patch)
tree69132df044e75fc256f80a50b13c9e03f19dee66 /program
parent4647e1bbb5beba82605695c4dc989ca867e53244 (diff)
Started implementing search function
Diffstat (limited to 'program')
-rw-r--r--program/steps/mail/search.inc101
1 files changed, 101 insertions, 0 deletions
diff --git a/program/steps/mail/search.inc b/program/steps/mail/search.inc
new file mode 100644
index 000000000..7b49ed84f
--- /dev/null
+++ b/program/steps/mail/search.inc
@@ -0,0 +1,101 @@
+<?php
+/*
+ +-----------------------------------------------------------------------+
+ | steps/mail/search.inc |
+ | |
+ | Search functions for rc webmail |
+ | Licensed under the GNU GPL |
+ | |
+ +-----------------------------------------------------------------------+
+ | Author: Benjamin Smith <defitro@gmail.com> |
+ +-----------------------------------------------------------------------+
+
+*/
+
+$REMOTE_REQUEST = TRUE;
+
+// reset list_page
+$IMAP->set_page(1);
+$_SESSION['page'] = 1;
+
+// get search string
+$str = get_input_value('_search', RCUBE_INPUT_GET);
+$mbox = get_input_value('_mbox', RCUBE_INPUT_GET);
+
+
+// Check the search string for type of search
+if (preg_match("/^from:/i", $str)) {
+ list(,$srch) = explode(":", $str);
+ $search = $IMAP->search($mbox, "FROM" ,trim($srch));
+ finish_search($mbox, $search);
+}
+else if (preg_match("/^to:/i", $str)) {
+ list(,$srch) = explode(":", $str);
+ $search = $IMAP->search($mbox, "TO", trim($srch));
+ finish_search($mbox, $search);
+}
+else if (preg_match("/^cc:/i", $str)) {
+ list(,$srch) = explode(":", $str);
+ $search = $IMAP->search($mbox, "CC", trim($srch));
+ finish_search($mbox, $search);
+}
+else if (preg_match("/^subject:/i", $str)) {
+ list(,$srch) = explode(":", $str);
+ $search = $IMAP->search($mbox, "SUBJECT", trim($srch));
+ finish_search($mbox, $search);
+}
+else if (preg_match("/^body:/i", $str)) {
+ list(,$srch) = explode(":", $str);
+ $search = $IMAP->search($mbox, "TEXT", trim($srch));
+ finish_search($mbox, $search);
+}
+// search in subject and sender by default
+else {
+ $search = $IMAP->search($mbox, "SUBJECT", trim($str));
+ $search2 = $IMAP->search($mbox, "FROM", trim($str));
+ finish_search($mbox, array_unique(array_merge($search, $search2)));
+}
+
+
+// Complete the search display results or report error
+function finish_search($mbox, $search)
+ {
+ global $IMAP, $JS_OBJECT_NAME, $OUTPUT;
+ $commands = '';
+ $count = 0;
+
+ // Make sure our $search is legit..
+ if (is_array($search) && $search[0] != '')
+ {
+ // Get the headers
+ $result_h = $IMAP->list_header_set($mbox, $search, 1, $_SESSION['sort_col'], $_SESSION['sort_order']);
+ $count = count($search);
+
+ // save search results in session
+ if (!is_array($_SESSION['search']))
+ $_SESSION['search'] = array();
+
+ $search_request = md5(uniqid(rand()));
+ $_SESSION['search'][$search_request] = join(',', $search);
+
+ // Make sure we got the headers
+ if ($result_h != NULL)
+ {
+ $count = count($result_h);
+ $commands = rcmail_js_message_list($result_h);
+ $commands .= show_message('searchsuccessful', 'confirmation', array('nr' => $count));
+ $commands .= sprintf("\nthis.set_env('search_request', '%s')\n", $search_request);
+ }
+ }
+ else
+ $commands = show_message('searchnomatch', 'warning');
+
+ // update message count display
+ $pages = ceil($count/$IMAP->page_size);
+ $commands .= sprintf("this.set_env('messagecount', %d);\n", $count);
+ $commands .= sprintf("this.set_env('pagecount', %d);\n", $pages);
+ $commands .= sprintf("this.set_rowcount('%s');\n", rcmail_get_messagecount_text($count, 1));
+ rcube_remote_response($commands);
+ }
+
+?> \ No newline at end of file