From 3509a8e5f8279de109007c0d975e36ffec1581d8 Mon Sep 17 00:00:00 2001
From: Aleksander Machniak <alec@alec.pl>
Date: Mon, 27 Jan 2014 04:31:28 -0500
Subject: [PATCH] Do not use rcube_config::all()

---
 program/include/rcmail.php |   35 +++++++++++++++++------------------
 1 files changed, 17 insertions(+), 18 deletions(-)

diff --git a/program/include/rcmail.php b/program/include/rcmail.php
index bb42cab..9c7ed98 100644
--- a/program/include/rcmail.php
+++ b/program/include/rcmail.php
@@ -492,17 +492,20 @@
             return false;
         }
 
-        $config = $this->config->all();
+        $default_host    = $this->config->get('default_host');
+        $default_port    = $this->config->get('default_port');
+        $username_domain = $this->config->get('username_domain');
+        $login_lc        = $this->config->get('login_lc', 2);
 
         if (!$host) {
-            $host = $config['default_host'];
+            $host = $default_host;
         }
 
         // Validate that selected host is in the list of configured hosts
-        if (is_array($config['default_host'])) {
+        if (is_array($default_host)) {
             $allowed = false;
 
-            foreach ($config['default_host'] as $key => $host_allowed) {
+            foreach ($default_host as $key => $host_allowed) {
                 if (!is_numeric($key)) {
                     $host_allowed = $key;
                 }
@@ -516,7 +519,7 @@
                 $host = null;
             }
         }
-        else if (!empty($config['default_host']) && $host != rcube_utils::parse_host($config['default_host'])) {
+        else if (!empty($default_host) && $host != rcube_utils::parse_host($default_host)) {
             $host = null;
         }
 
@@ -533,23 +536,23 @@
 
             if (!empty($a_host['port']))
                 $port = $a_host['port'];
-            else if ($ssl && $ssl != 'tls' && (!$config['default_port'] || $config['default_port'] == 143))
+            else if ($ssl && $ssl != 'tls' && (!$default_port || $default_port == 143))
                 $port = 993;
         }
 
         if (!$port) {
-            $port = $config['default_port'];
+            $port = $default_port;
         }
 
         // Check if we need to add/force domain to username
-        if (!empty($config['username_domain'])) {
-            $domain = is_array($config['username_domain']) ? $config['username_domain'][$host] : $config['username_domain'];
+        if (!empty($username_domain)) {
+            $domain = is_array($username_domain) ? $username_domain[$host] : $username_domain;
 
             if ($domain = rcube_utils::parse_host((string)$domain, $host)) {
                 $pos = strpos($username, '@');
 
                 // force configured domains
-                if (!empty($config['username_domain_forced']) && $pos !== false) {
+                if ($pos !== false && $this->config->get('username_domain_forced')) {
                     $username = substr($username, 0, $pos) . '@' . $domain;
                 }
                 // just add domain if not specified
@@ -559,14 +562,10 @@
             }
         }
 
-        if (!isset($config['login_lc'])) {
-            $config['login_lc'] = 2; // default
-        }
-
         // Convert username to lowercase. If storage backend
         // is case-insensitive we need to store always the same username (#1487113)
-        if ($config['login_lc']) {
-            if ($config['login_lc'] == 2 || $config['login_lc'] === true) {
+        if ($login_lc) {
+            if ($login_lc == 2 || $login_lc === true) {
                 $username = mb_strtolower($username);
             }
             else if (strpos($username, '@')) {
@@ -604,7 +603,7 @@
             $user->touch();
         }
         // create new system user
-        else if ($config['auto_create_user']) {
+        else if ($this->config->get('auto_create_user')) {
             if ($created = rcube_user::create($username, $host)) {
                 $user = $created;
             }
@@ -651,7 +650,7 @@
             $this->fix_namespace_settings($user);
 
             // create default folders on login
-            if ($config['create_default_folders']) {
+            if ($this->config->get('create_default_folders')) {
                 $storage->create_default_folders();
             }
 

--
Gitblit v1.9.1