some more fixes to solve the vhost problem (icy cold here in the freeze)
[squirrelmail.git] / src / addrbook_search_html.php
index d28825289ccb3b75240b499b79ff019a5f937b06..585680dc018a97fca25e5353d740929272afd36d 100644 (file)
 <?php
-   /**
-    **  addrbook_search.php
-    **
-    **  Handle addressbook searching with pure html.  This file is included from compose.php 
-    **
-    **/
-
-   session_start();
-
-   if (!isset($config_php))
-      include("../config/config.php");
-   if (!isset($strings_php))
-      include("../functions/strings.php");
-   if (!isset($page_header_php))
-      include("../functions/page_header.php");
-   if (!isset($imap_php))
-      include("../functions/imap.php");
-   if (!isset($date_php))
-      include("../functions/date.php");
-   if (!isset($mime_php))
-      include("../functions/mime.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");
-
-   include("../src/load_prefs.php");
-
-
-   echo "<HTML><BODY TEXT=\"$color[8]\" BGCOLOR=\"$color[4]\" LINK=\"$color[7]\" VLINK=\"$color[7]\" ALINK=\"$color[7]\">\n";
-   displayPageHeader($color, "None");
-   //<form method=post action="compose.php?html_addr_search=true">
-
-   
-   $body = stripslashes($body);
-   $send_to = stripslashes($send_to);
-   $send_to_cc = stripslashes($send_to_cc);
-   $send_to_bcc = stripslashes($send_to_bcc);
-   $subject = stripslashes($subject);
-
-   echo "<center>";
-   echo "<form method=post action=\"compose.php?html_addr_search=true\">";
-   echo "   <input type=text value=\"$query\"name=query>";
-   echo "   <input type=submit value=Submit>";
-   echo "   <input type=hidden value=\"$body\" name=body>";
-   echo "   <input type=hidden value=\"$subject\" name=subject>";
-   echo "   <input type=hidden value=\"$send_to\" name=send_to>";
-   echo "   <input type=hidden value=\"$send_to_cc\" name=send_to_cc>";
-   echo "   <input type=hidden value=\"$send_to_bcc\" name=send_to_bcc>";
-   echo "</form>";
-   echo "</center>";
-
-   if(!empty($query)) {
-      $abook = addressbook_init();
-      $res = $abook->s_search($query);
-
-      if(!is_array($res)) {
-         printf("<P ALIGN=center><BR>%s:<br>%s</P>\n</BODY></HTML>\n",
-                _("Your search failed with the following error(s)"),
-                $abook->error);
-         exit;
-      }
-
-      if(sizeof($res) == 0) {
-         printf("<P ALIGN=center><BR>%s.</P>\n</BODY></HTML>\n",
-                _("No persons matching your search was found"));
-         exit;
-      }
-
-      // List search results
-      $line = 0;
-      print "<table border=0 width=\"98%\" align=center>";
-      printf("<tr bgcolor=\"$color[9]\"><TH align=left>&nbsp;".
-             "<TH align=left>&nbsp;%s<TH align=left>&nbsp;%s".
-             "<TH align=left>&nbsp;%s<TH align=left width=\"10%%\">".
-             "&nbsp;%s</tr>\n",
-             _("Name"), _("E-mail"), _("Info"), _("Source"));
-
-      ?> 
-         <form method=post action"compose.php?html_addr_search_done=true"> 
-      <?
-   echo "   <input type=hidden value=\"$body\" name=body>";
-   echo "   <input type=hidden value=\"$subject\" name=subject>";
-   echo "   <input type=hidden value=\"$send_to\" name=send_to>";
-   echo "   <input type=hidden value=\"$send_to_cc\" name=send_to_cc>";
-   echo "   <input type=hidden value=\"$send_to_bcc\" name=send_to_bcc>";
-      
-      while(list($key, $row) = each($res)) {
-         printf("<tr%s nowrap><td nowrap align=center width=\"5%%\">".
-                "<input type=checkbox name=send_to_search[] value=\"%s\">&nbsp;To".
-                "<input type=checkbox name=send_to_cc_search[] value=\"%s\">&nbsp;Cc&nbsp;".
-                "<td nowrap>&nbsp;%s&nbsp;<td nowrap>&nbsp;".
-                "%s".
-                "<td nowrap>&nbsp;%s&nbsp;<td nowrap>&nbsp;%s</tr>\n",
-                ($line % 2) ? " bgcolor=\"$color[0]\"" : "", $row["email"],
-                $row["email"], $row["name"], $row["email"],
-                $row["label"], $row["source"]);
-         $line++;
-      }
-      print "</TABLE>";
-      echo "<input type=hidden value=1 name=html_addr_search_done>";
-      echo "<center><input type=submit value=addr_search_done name=\"Use Addresses\"></center>";
-      echo "</form>";
+
+/**
+ * addrbook_search_html.php
+ *
+ * Copyright (c) 1999-2002 The SquirrelMail Project 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$
+ */
+
+require_once('../src/validate.php');
+require_once('../functions/date.php');
+require_once('../functions/smtp.php');
+require_once('../functions/display_messages.php');
+require_once('../functions/addressbook.php');
+require_once('../functions/plugin.php');
+include_once('../functions/strings.php');
+
+/* Insert hidden data */
+function addr_insert_hidden() {
+    global $body, $subject, $send_to, $send_to_cc, $send_to_bcc, $mailbox,
+           $identity;
+
+   echo '<input type=hidden value="';
+   if (substr($body, 0, 1) == "\r")
+       echo "\n";
+   echo htmlspecialchars($body) . '" name=body>' . "\n" .
+        '<input type=hidden value="' . htmlspecialchars($subject) .
+        '" name=subject>' . "\n" .
+        '<input type=hidden value="' . htmlspecialchars($send_to) .
+        '" name=send_to>' . "\n" .
+        '<input type=hidden value="' . htmlspecialchars($send_to_cc) .
+        '" name=send_to_cc>' . "\n" .
+        '<input type=hidden value="' . htmlspecialchars($send_to_bcc) .
+        '" name=send_to_bcc>' . "\n" .
+        '<input type=hidden value="' . htmlspecialchars($identity) .
+        '" name=identity>' . "\n" .
+        '<input type=hidden name=mailbox value="' . htmlspecialchars($mailbox) .
+        "\">\n" . '<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;
+
+    echo '<form method=post action="' . $PHP_SELF . "\">\n" .
+         '<input type=hidden name="html_addr_search_done" value="true">' . "\n";
+    addr_insert_hidden();
+    $line = 0;
+
+    echo '<TABLE BORDER=0 WIDTH="98%" ALIGN=center>' .
+         '<TR BGCOLOR="' . $color[9] . '"><TH ALIGN=left>&nbsp;' .
+         '<TH ALIGN=left>&nbsp;' . _("Name") .
+         '<TH ALIGN=left>&nbsp;' . _("E-mail") .
+         '<TH ALIGN=left>&nbsp;' . _("Info");
+
+    if ($includesource) {
+        echo '<TH ALIGN=left WIDTH="10%">&nbsp;' . _("Source");
+    }
+
+    echo "</TR>\n";
+
+    foreach ($res as $row) {
+        echo '<tr';
+        if ($line % 2) { echo ' bgcolor="' . $color[0] . '"'; }
+        echo ' nowrap><td nowrap align=center width="5%">' .
+             '<input type=checkbox name="send_to_search[T' . $line . ']" value = "' .
+             htmlspecialchars($row['email']) . '">&nbsp;To&nbsp;' .
+             '<input type=checkbox name="send_to_search[C' . $line . ']" value = "' .
+             htmlspecialchars($row['email']) . '">&nbsp;Cc&nbsp;' .
+             '<input type=checkbox name="send_to_search[B' . $line . ']" value = "' .
+             htmlspecialchars($row['email']) . '">&nbsp;Bcc&nbsp;' . 
+             '</td><td nowrap>&nbsp;' . $row['name'] . '&nbsp;</td>' .
+             '<td nowrap>&nbsp;' . $row['email'] . '&nbsp;</td>' .
+             '<td nowrap>&nbsp;' . $row['label'] . '&nbsp;</td>';
+         if ($includesource) {
+             echo '<td nowrap>&nbsp;' . $row['source'] . '&nbsp;</td>';
+         }
+         echo "</tr>\n";
+         $line ++;
+    }
+    echo '<TR><TD ALIGN=center COLSPAN=';
+    if ($includesource) { echo '4'; } else { echo '5'; }
+    echo '><INPUT TYPE=submit NAME="addr_search_done" VALUE="' .
+         _("Use Addresses") . '"></TD></TR>' .
+         '</TABLE>' .
+         '<INPUT TYPE=hidden VALUE=1 NAME="html_addr_search_done">' .
+         '</FORM>';
+}
+
+/* --- End functions --- */
+
+global $mailbox;
+displayPageHeader($color, $mailbox);
+
+/* 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 */
+echo "<CENTER>\n<TABLE BORDER=0><TR><TD NOWRAP VALIGN=middle>\n" .
+     '<FORM METHOD=post NAME=f ACTION="' . $PHP_SELF .
+     '?html_addr_search=true">' . "\n<CENTER>\n" .
+     '  <nobr><STRONG>' . _("Search for") . "</STRONG>\n";
+addr_insert_hidden();
+if (! isset($addrquery))
+    $addrquery = '';
+echo '  <INPUT TYPE=text NAME=addrquery VALUE="' .
+     htmlspecialchars($addrquery) . "\" SIZE=26>\n";
+
+/* List all backends to allow the user to choose where to search */
+if (!isset($backend)) { $backend = ''; }
+if ($abook->numbackends > 1) {
+    echo '<STRONG>' . _("in") . '</STRONG>&nbsp;<SELECT NAME=backend>' . "\n" .
+         '<OPTION VALUE=-1';
+    if ($backend == -1) { echo ' SELECTED'; }
+    echo '>' . _("All address books") . "\n";
+    $ret = $abook->get_backend_list();
+    while (list($undef,$v) = each($ret)) {
+        echo '<OPTION VALUE=' . $v->bnum;
+        if ($backend == $v->bnum) { echo ' SELECTED'; }
+        echo '>' . $v->sname . "\n";
+    }
+    echo "</SELECT>\n";
+} else {
+    echo '<INPUT TYPE=hidden NAME=backend VALUE=-1>' . "\n";
+}
+echo '<INPUT TYPE=submit VALUE="' . _("Search") . '">' .
+     '&nbsp;|&nbsp;<INPUT TYPE=submit VALUE="' . _("List all") .
+     '" NAME=listall>' . "\n" .
+     '</FORM></center></TD></TR></TABLE>' . "\n";
+addr_insert_hidden();
+echo '</CENTER>';
+do_hook('addrbook_html_search_below');
+/* End search form */
+
+/* Show personal addressbook */
+if ($addrquery == '' || !empty($listall)) {
+
+    if (! isset($backend) || $backend != -1 || $addrquery == '') {
+        if ($addrquery == '') {
+            $backend = $abook->localbackend;
+        }
+
+        /* echo '<H3 ALIGN=center>' . $abook->backends[$backend]->sname) . "</H3>\n"; */
+
+        $res = $abook->list_addr($backend);
+
+        if (is_array($res)) {
+            usort($res,'alistcmp');
+            addr_display_result($res, false);
+        } else {
+            echo '<P ALIGN=center><STRONG>' .
+                 sprintf(_("Unable to list addresses from %s"), 
+                     $abook->backends[$backend]->sname) .
+                 "</STRONG></P>\n";
+        }
+
+    } else {
+        $res = $abook->list_addr();
+        usort($res,'alistcmp');
+        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)) {
+            echo '<P ALIGN=center><B><BR>' .
+                 _("Your search failed with the following error(s)") . ':<br>' .
+                  $abook->error . "</B></P>\n</BODY></HTML>\n";
+        } else {
+            if (sizeof($res) == 0) {
+                echo '<P ALIGN=center><BR><B>' .
+                     _("No persons matching your search was found") .
+                     ".</B></P>\n</BODY></HTML>\n";
+            } else {
+                addr_display_result($res);
+            }
+        }
+    }
+}
+
+if ($addrquery == '' || sizeof($res) == 0) {
+    /* printf('<center><FORM METHOD=post NAME=k ACTION="compose.php">'."\n", $PHP_SELF); */
+    echo '<center><FORM METHOD=post NAME=k ACTION="compose.php">' . "\n";
+    addr_insert_hidden();
+    echo '<INPUT TYPE=submit VALUE="' . _("Return") . '" NAME=return>' . "\n" .
+         '</form></center></nobr>';
+}
+
 ?>
+</body></html>