<?php
- /**
- ** addrbook_search.php
- **
- ** Copyright (c) 1999-2000 The SquirrelMail development team
- ** Licensed under the GNU GPL. For full terms see the file COPYING.
- **
- ** Handle addressbook searching with pure html.
- **
- ** This file is included from compose.php
- **
- ** NOTE: A lot of this code is similar to the code in
- ** addrbook_search.html -- If you change one, change
- ** the other one too!
- **
- ** $Id$
- **/
-
- session_start();
-
- if (!isset($config_php))
- include('../config/config.php');
- if (!isset($strings_php))
- include('../functions/strings.php');
- if (!isset($auth_php))
- include('../functions/auth.php');
- if (!isset($page_header_php))
- include('../functions/page_header.php');
- if (!isset($date_php))
- include('../functions/date.php');
- if (!isset($smtp_php))
- include('../functions/smtp.php');
- if (!isset($display_messages_php))
- include('../functions/display_messages.php');
- if (!isset($addressbook_php))
- include('../functions/addressbook.php');
- if (!isset($plugin_php))
- include('../functions/plugin.php');
-
- include('../src/load_prefs.php');
-
- // Insert hidden data
- function addr_insert_hidden() {
- global $body, $subject, $send_to, $send_to_cc, $send_to_bcc;
-
- echo '<input type=hidden value="';
- if (substr($body, 0, 1) == "\r")
- echo "\n";
- echo htmlspecialchars($body) . '" name=body>' . "\n";
- echo '<input type=hidden value="' . htmlspecialchars($subject)
- . '" name=subject>' . "\n";
- echo '<input type=hidden value="' . htmlspecialchars($send_to)
- . '" name=send_to>' . "\n";
- echo "<input type=hidden value=\"" . htmlspecialchars($send_to_cc)
- . '" name=send_to_cc>' . "\n";
- echo "<input type=hidden value=\"" . htmlspecialchars($send_to_bcc)
- . '" name=send_to_bcc>' . "\n";
- echo "<input type=hidden value=\"true\" name=from_htmladdr_search>\n";
- }
-
-
- // List search results
- function addr_display_result($res, $includesource = true) {
- global $color, $PHP_SELF;
-
- if(sizeof($res) <= 0) return;
-
- printf('<FORM METHOD=post ACTION="%s?html_addr_search_done=true">'."\n",
- $PHP_SELF);
- addr_insert_hidden();
- $line = 0;
-
- print "<TABLE BORDER=0 WIDTH=\"98%\" ALIGN=center>";
- printf("<TR BGCOLOR=\"$color[9]\"><TH ALIGN=left> ".
- "<TH ALIGN=left> %s<TH ALIGN=left> %s".
- "<TH ALIGN=left> %s",
- _("Name"), _("E-mail"), _("Info"));
-
- if($includesource)
- printf("<TH ALIGN=left WIDTH=\"10%%\"> %s", _("Source"));
-
- print "</TR>\n";
-
- while(list($undef, $row) = each($res)) {
- printf("<tr%s nowrap><td nowrap align=center width=\"5%%\">".
- "<input type=checkbox name=\"send_to_search[]\" value=\"%s\"> To".
- "<input type=checkbox name=\"send_to_cc_search[]\" value=\"%s\"> Cc ".
- "<td nowrap> %s <td nowrap> ".
- "%s".
- "<td nowrap> %s ",
- ($line % 2) ? " bgcolor=\"$color[0]\"" : "",
- htmlspecialchars($row["email"]), htmlspecialchars($row["email"]),
- $row["name"], $row["email"], $row["label"]);
- if($includesource)
- printf("<td nowrap> %s", $row["source"]);
-
- print "</TR>\n";
- $line++;
- }
- printf('<TR><TD ALIGN=center COLSPAN=%d><INPUT TYPE=submit '.
- 'NAME="addr_search_done" VALUE="%s"></TD></TR>',
- 4 + ($includesource ? 1 : 0),
- _("Use Addresses"));
- print '</TABLE>';
- print '<INPUT TYPE=hidden VALUE=1 NAME="html_addr_search_done">';
- print '</FORM>';
- }
-
- // --- End functions ---
-
- displayPageHeader($color, 'None');
-
- // Initialize addressbook
- $abook = addressbook_init();
-
-?>
-
-<br>
-<table width=95% align=center cellpadding=2 cellspacing=2 border=0>
-<tr><td bgcolor="<?php echo $color[0] ?>">
- <center><b><?php echo _("Address Book Search") ?></b></center>
-</td></tr></table>
-
-<?php
- // Search form
- print "<CENTER>\n";
- print "<TABLE BORDER=0>\n";
- print "<TR><TD NOWRAP VALIGN=middle>\n";
- printf('<FORM METHOD=post NAME=f ACTION="%s?html_addr_search=true">'."\n", $PHP_SELF);
- print "<CENTER>\n";
- printf(" <nobr><STRONG>%s</STRONG>\n", _("Search for"));
- addr_insert_hidden();
- if (! isset($addrquery))
- $addrquery = "";
- printf(" <INPUT TYPE=text NAME=addrquery VALUE=\"%s\" SIZE=26>\n",
- htmlspecialchars($addrquery));
-
- // List all backends to allow the user to choose where to search
- if($abook->numbackends > 1) {
- printf("<STRONG>%s</STRONG> <SELECT NAME=backend>\n",
- _("in"));
- printf("<OPTION VALUE=-1 %s>%s\n",
- ($backend == -1) ? "SELECTED" : "",
- _("All address books"));
- $ret = $abook->get_backend_list();
- while(list($undef,$v) = each($ret))
- printf("<OPTION VALUE=%d %s>%s\n",
- $v->bnum,
- ($backend == $v->bnum) ? "SELECTED" : "",
- $v->sname);
- print "</SELECT>\n";
+/**
+ * addrbook_search_html.php
+ *
+ * Handle addressbook searching with pure html.
+ *
+ * This file is included from compose.php
+ *
+ * @copyright © 1999-2007 The SquirrelMail Project Team
+ * @license http://opensource.org/licenses/gpl-license.php GNU Public License
+ * @version $Id$
+ * @package squirrelmail
+ * @subpackage addressbook
+ */
+
+/**
+ * Include the SquirrelMail initialization file.
+ * Because this file can also be included within compose we check for the $bInit
+ * var which is set inside ini.php. It's needed because compose already includes
+ * init.php.
+ */
+if (!isset($bInit)) {
+ /** This is the addrbook_search_html page */
+ define('PAGE_NAME', 'addrbook_search_html');
+
+ include('../include/init.php');
+}
+
+/** SquirrelMail required files. */
+include_once(SM_PATH . 'functions/date.php');
+include_once(SM_PATH . 'functions/addressbook.php');
+include_once(SM_PATH . 'templates/util_addressbook.php');
+
+sqgetGlobalVar('session', $session, SQ_POST);
+sqgetGlobalVar('mailbox', $mailbox, SQ_POST);
+if (! sqgetGlobalVar('query', $addrquery, SQ_POST))
+ $addrquery='';
+sqgetGlobalVar('listall', $listall, SQ_POST);
+sqgetGlobalVar('backend', $backend, SQ_POST);
+
+/**
+ * Insert hidden data
+ */
+function addr_insert_hidden() {
+ global $body, $subject, $send_to, $send_to_cc, $send_to_bcc, $mailbox, $mailprio,
+ $request_mdn, $request_dr, $identity, $session, $composeMessage;
+
+//FIXME Do not echo HTML from the core. This file already uses templates mostly, so why are we echoing here at all?!?
+ if (substr($body, 0, 1) == "\r") {
+ echo addHidden('body', "\n".$body);
} else {
- print "<INPUT TYPE=hidden NAME=backend VALUE=-1>\n";
+ echo addHidden('body', $body);
}
- printf("<INPUT TYPE=submit VALUE=\"%s\">",
- _("Search"));
- printf(" | <INPUT TYPE=submit VALUE=\"%s\" NAME=listall>\n",
- _("List all"));
- print '</FORM></center>';
-
- print "</TD></TR></TABLE>\n";
- addr_insert_hidden();
- print "</CENTER>";
- do_hook('addrbook_html_search_below');
- // End search form
-
- // Show personal addressbook
- if(!isset($addrquery) || !empty($listall)) {
-
- if(! isset($backend) || $backend != -1 || !isset($addrquery)) {
- if(!isset($addrquery))
- $backend = $abook->localbackend;
- //printf("<H3 ALIGN=center>%s</H3>\n", $abook->backends[$backend]->sname);
+ if (is_object($composeMessage) && $composeMessage->entities)
+ echo addHidden('attachments', serialize($composeMessage->entities));
+
+ echo addHidden('session', $session).
+ addHidden('subject', $subject).
+ addHidden('send_to', $send_to).
+ addHidden('send_to_bcc', $send_to_bcc).
+ addHidden('send_to_cc', $send_to_cc).
+ addHidden('mailprio', $mailprio).
+ addHidden('request_mdn', $request_mdn).
+ addHidden('request_dr', $request_dr).
+ addHidden('identity', $identity).
+ addHidden('mailbox', $mailbox).
+ addHidden('from_htmladdr_search', 'true');
+}
+
+
+/**
+ * List search results
+ * @param array $res Array containing results of search
+ * @param bool $includesource If true, adds backend column to address listing
+ */
+function addr_display_result($res, $includesource = true) {
+ global $PHP_SELF, $oTemplate, $oErrorHandler;
+
+
+ echo addForm($PHP_SELF, 'post', 'addressbook').
+ addHidden('html_addr_search_done', 'true');
+ addr_insert_hidden();
+
+ $oTemplate->assign('use_js', false);
+ $oTemplate->assign('include_abook_name', $includesource);
+ $oTemplate->assign('addresses', formatAddressList($res));
+
+ $oTemplate->display('addrbook_search_list.tpl');
+
+ echo '</form>';
+}
+
+/* --- End functions --- */
+
+if ($compose_new_win == '1') {
+ compose_Header($color, $mailbox);
+}
+else {
+ displayPageHeader($color, $mailbox);
+}
+
+/** set correct value of $default_charset */
+set_my_charset();
+
+/* Initialize addressbook */
+$abook = addressbook_init();
+
+
+/* Search form */
+echo addForm($PHP_SELF.'?html_addr_search=true', 'post', 'f');
+addr_insert_hidden();
+if (isset($session)) {
+ echo addHidden('session', $session);
+}
+
+$oTemplate->assign('use_js', false);
+$oTemplate->assign('backends', getBackends());
+
+$oTemplate->display('addressbook_search_form.tpl');
+
+echo "</form>\n";
+do_hook('addrbook_html_search_below', $null);
+/* End search form */
+
+/* List addresses. Show personal addressbook */
+if ($addrquery == '' || ! empty($listall)) {
+ // TODO: recheck all conditions and simplity if statements
+ if (! isset($backend) || $backend != -1 || $addrquery == '') {
+ if ($addrquery == '' && empty($listall)) {
+ $backend = $abook->localbackend;
+ }
- $res = $abook->list_addr($backend);
+ $res = $abook->list_addr($backend);
- if(is_array($res)) {
+ if (is_array($res)) {
+ usort($res,'alistcmp');
addr_display_result($res, false);
- } else {
- printf("<P ALIGN=center><STRONG>"._("Unable to list addresses from %s").
- "</STRONG></P>\n", $abook->backends[$backend]->sname);
- }
-
- } else {
- $res = $abook->list_addr();
- addr_display_result($res, true);
- }
- exit;
-
- } else
-
- // Do the search
- if(!empty($addrquery) && empty($listall)) {
-
- if($backend == -1) {
- $res = $abook->s_search($addrquery);
- } else {
- $res = $abook->s_search($addrquery, $backend);
- }
-
- if(!is_array($res)) {
- printf("<P ALIGN=center><B><BR>%s:<br>%s</B></P>\n</BODY></HTML>\n",
- _("Your search failed with the following error(s)"),
- $abook->error);
- } else if(sizeof($res) == 0) {
- printf("<P ALIGN=center><BR><B>%s.</B></P>\n</BODY></HTML>\n",
- _("No persons matching your search was found"));
- } else {
- addr_display_result($res);
- }
- }
-
- if (!$addrquery || sizeof($res) == 0) {
- printf('<center><FORM METHOD=post NAME=k ACTION="compose.php">'."\n", $PHP_SELF);
- addr_insert_hidden();
- printf("<INPUT TYPE=submit VALUE=\"%s\" NAME=return>\n", _("Return"));
- print '</form>';
- print '</center></nobr>';
- }
-
-?>
-</body></html>
+ } else {
+ plain_error_message(_("Unable to list addresses from %s"), $abook->backends[$backend]->sname);
+ }
+
+ } else {
+ $res = $abook->list_addr();
+ usort($res,'alistcmp');
+ addr_display_result($res, true);
+ }
+ $oTemplate->display('footer.tpl');
+ exit;
+} elseif (!empty($addrquery)) {
+ /* Do the search */
+ if ($backend == -1) {
+ $res = $abook->s_search($addrquery);
+ } else {
+ $res = $abook->s_search($addrquery, $backend);
+ }
+
+ if (!is_array($res)) {
+ plain_error_message(_("Your search failed with the following error(s)") .':<br />'. nl2br(htmlspecialchars($abook->error)));
+ } elseif (sizeof($res) == 0) {
+ $oTemplate->assign('note', _("No persons matching your search were found"));
+ $oTemplate->display('note.tpl');
+ } else {
+ addr_display_result($res);
+ }
+} else {
+ // not first time display, not listall and search is empty
+ // TODO: I think, this part of control structure is never reached.
+ plain_error_message(_("Nothing to search"));
+}
+
+if ($addrquery == '' || sizeof($res) == 0) {
+//FIXME don't echo HTML from core -- especially convoluted given that there is template code immediately above AND below this block
+ echo '<div style="text-align: center;">'.
+ addForm('compose.php','post','k');
+ addr_insert_hidden();
+ echo '<input type="submit" value="' . _("Return") . '" name="return" />' . "\n" .
+ '</form></div></nobr>';
+}
+
+echo '<hr />';
+
+$oTemplate->display('footer.tpl');