summaryrefslogtreecommitdiff
path: root/program/include/rcmail.php
diff options
context:
space:
mode:
authoralecpl <alec@alec.pl>2010-01-28 12:52:24 +0000
committeralecpl <alec@alec.pl>2010-01-28 12:52:24 +0000
commitb5846eed4ddd8e2a3f5f0fee42d91d5243c2afec (patch)
tree8584ddd42301ef347635e975da603d3665909c33 /program/include/rcmail.php
parent10eedbe75a2022d65ec349de5f3bd12400191974 (diff)
- Login preformance: Create default folders on first login only
Diffstat (limited to 'program/include/rcmail.php')
-rw-r--r--program/include/rcmail.php15
1 files changed, 8 insertions, 7 deletions
diff --git a/program/include/rcmail.php b/program/include/rcmail.php
index 1afb7d72a..e3c826111 100644
--- a/program/include/rcmail.php
+++ b/program/include/rcmail.php
@@ -492,17 +492,22 @@ class rcmail
if (!($imap_login = $this->imap->connect($host, $username, $pass, $imap_port, $imap_ssl)))
return false;
+ $this->set_imap_prop();
+
// user already registered -> update user's record
if (is_object($user)) {
+ // create default folders on first login
+ if (!$user->data['last_login'] && $config['create_default_folders'])
+ $this->imap->create_default_folders();
$user->touch();
}
// create new system user
else if ($config['auto_create_user']) {
if ($created = rcube_user::create($username, $host)) {
$user = $created;
-
- // get existing mailboxes (but why?)
- // $a_mailboxes = $this->imap->list_mailboxes();
+ // create default folders on first login
+ if ($config['create_default_folders'])
+ $this->imap->create_default_folders();
}
else {
raise_error(array(
@@ -537,12 +542,8 @@ class rcmail
$_SESSION['timezone'] = floatval($_REQUEST['_timezone']);
// force reloading complete list of subscribed mailboxes
- $this->set_imap_prop();
$this->imap->clear_cache('mailboxes');
- if ($config['create_default_folders'])
- $this->imap->create_default_folders();
-
return true;
}