X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fimap_general.php;h=83ffe7e68fcd607986d4a8fcb2cb5334f9481047;hb=4656211357cb4f494081f6b73235f015994c2e8c;hp=f047f3036d978b60a3ca2ec6f8a8e6b30fb010b0;hpb=2c898a113f1e765b06eb92b09d2a80a30e7036b7;p=squirrelmail.git
diff --git a/functions/imap_general.php b/functions/imap_general.php
index f047f303..83ffe7e6 100755
--- a/functions/imap_general.php
+++ b/functions/imap_general.php
@@ -1,4 +1,4 @@
-
+$read
";
$counter = 0;
while ((substr($read, 0, strlen("$pre OK")) != "$pre OK") &&
(substr($read, 0, strlen("$pre BAD")) != "$pre BAD") &&
(substr($read, 0, strlen("$pre NO")) != "$pre NO")) {
$data[$counter] = $read;
$read = fgets ($imap_stream, 1024);
+ if ($imap_general_debug) echo "$read
";
$counter++;
}
+ if ($imap_general_debug) echo "--
";
if (substr($read, 0, strlen("$pre OK")) == "$pre OK") {
$response = "OK";
$message = trim(substr($read, strlen("$pre OK"), strlen($read)));
@@ -37,18 +43,18 @@
if ($handle_errors == true) {
if ($response == "NO") {
- echo "
";
+ echo "
\n";
echo _("ERROR : Could not complete request.");
- echo "
";
+ echo "
\n";
echo _("Reason Given: ");
- echo "$message
";
+ echo "$message
\n";
exit;
} else if ($response == "BAD") {
- echo "
";
+ echo "
\n";
echo _("ERROR : Bad or malformed request.");
- echo "
";
+ echo "
\n";
echo _("Server responded: ");
- echo "$message
";
+ echo "$message
\n";
exit;
}
}
@@ -64,14 +70,26 @@
** will be displayed. This function returns the imap connection handle.
******************************************************************************/
function sqimap_login ($username, $password, $imap_server_address, $imap_port, $hide) {
- global $color;
+ global $color, $squirrelmail_language, $HTTP_ACCEPT_LANGUAGE, $onetimepad;
+
$imap_stream = fsockopen ($imap_server_address, $imap_port, &$error_number, &$error_string);
$server_info = fgets ($imap_stream, 1024);
+ // Decrypt the password
+ $password = OneTimePadDecrypt($password, $onetimepad);
+
+ // This function can sometimes be called before the check for
+ // gettext is done.
+ if (!function_exists("_")) {
+ function _($string) {
+ return $string;
+ }
+ }
+
/** Do some error correction **/
if (!$imap_stream) {
if (!$hide) {
- echo "Error connecting to IMAP server: $imap_server_address.
\r\n";
+ printf (_("Error connecting to IMAP server: %s.")."
\r\n", $imap_server_address);
echo "$error_number : $error_string
\r\n";
}
exit;
@@ -84,9 +102,33 @@
if (substr($read, 0, 7) != "a001 OK") {
if (!$hide) {
if (substr($read, 0, 8) == "a001 BAD") {
- echo "Bad request: $read
\r\n";
+ printf (_("Bad request: %s")."
\r\n", $read);
exit;
} else if (substr($read, 0, 7) == "a001 NO") {
+ // If the user does not log in with the correct
+ // username and password it is not possible to get the
+ // correct locale from the user's preferences.
+ // Therefore, apply the same hack as on the login
+ // screen.
+
+ // $squirrelmail_language is set by a cookie when
+ // the user selects language and logs out
+
+ // Use HTTP content language negotiation if cookie
+ // not set
+ if (!isset($squirrelmail_language) && isset($HTTP_ACCEPT_LANGUAGE)) {
+ $squirrelmail_language = substr($HTTP_ACCEPT_LANGUAGE, 0, 2);
+ }
+
+ if (isset($squirrelmail_language) && function_exists("bindtextdomain")) {
+ if ($squirrelmail_language != "en" && $squirrelmail_language != "") {
+ putenv("LC_ALL=".$squirrelmail_language);
+ bindtextdomain("squirrelmail", "../locale/");
+ textdomain("squirrelmail");
+ header ("Content-Type: text/html; charset=".$languages[$squirrelmail_language]["CHARSET"]);
+ }
+ }
+
?>