From 111f5098d532b4eba47f2a496ed02d2203077690 Mon Sep 17 00:00:00 2001
From: alecpl <alec@alec.pl>
Date: Mon, 23 Apr 2012 03:13:29 -0400
Subject: [PATCH] - Implement set/get helper methods in rcube_message_header class

---
 plugins/subscriptions_option/subscriptions_option.php |   57 ++++++++++++++++++++++++++++++---------------------------
 1 files changed, 30 insertions(+), 27 deletions(-)

diff --git a/plugins/subscriptions_option/subscriptions_option.php b/plugins/subscriptions_option/subscriptions_option.php
index 488146a..28f8262 100644
--- a/plugins/subscriptions_option/subscriptions_option.php
+++ b/plugins/subscriptions_option/subscriptions_option.php
@@ -19,23 +19,23 @@
  * 'dont_override' list and the global option has changed, don't expect
  * to see the change until the folder list cache is refreshed.
  *
- * @version 1.0
+ * @version @package_version@
  * @author Ziba Scott
  */
 class subscriptions_option extends rcube_plugin
 {
     public $task = 'mail|settings';
-    
+
     function init()
     {
         $this->add_texts('localization/', false);
         $dont_override = rcmail::get_instance()->config->get('dont_override', array());
         if (!in_array('use_subscriptions', $dont_override)) {
-            $this->add_hook('user_preferences', array($this, 'settings_blocks'));
-            $this->add_hook('save_preferences', array($this, 'save_prefs'));
+            $this->add_hook('preferences_list', array($this, 'settings_blocks'));
+            $this->add_hook('preferences_save', array($this, 'save_prefs'));
         }
-        $this->add_hook('list_mailboxes', array($this, 'list_mailboxes'));
-        $this->add_hook('manage_folders', array($this, 'manage_folders'));
+        $this->add_hook('storage_folders', array($this, 'mailboxes_list'));
+        $this->add_hook('folders_list', array($this, 'folders_list'));
     }
 
     function settings_blocks($args)
@@ -45,10 +45,10 @@
             $field_id = 'rcmfd_use_subscriptions';
             $checkbox = new html_checkbox(array('name' => '_use_subscriptions', 'id' => $field_id, 'value' => 1));
 
-            $args['blocks']['main']['options'][] = array(
-		'title' => html::label($field_id, Q($this->gettext('useimapsubscriptions'))),
+            $args['blocks']['main']['options']['use_subscriptions'] = array(
+                'title' => html::label($field_id, Q($this->gettext('useimapsubscriptions'))),
                 'content' => $checkbox->show($use_subscriptions?1:0),
-	    );
+            );
         }
 
         return $args;
@@ -57,31 +57,34 @@
     function save_prefs($args)
     {
         if ($args['section'] == 'server') {
-    	    $rcmail = rcmail::get_instance();
+            $rcmail = rcmail::get_instance();
             $use_subscriptions = $rcmail->config->get('use_subscriptions');
 
-    	    $args['prefs']['use_subscriptions'] = isset($_POST['_use_subscriptions']) ? true : false;
+            $args['prefs']['use_subscriptions'] = isset($_POST['_use_subscriptions']) ? true : false;
 
-    	    // if the use_subscriptions preference changes, flush the folder cache
-    	    if (($use_subscriptions && !isset($_POST['_use_subscriptions'])) ||
-        	(!$use_subscriptions && isset($_POST['_use_subscriptions']))) {
-            	    $rcmail->imap_init(true);
-            	    $rcmail->imap->clear_cache('mailboxes');
-    	    }
-	}
-        return $args;
-    }
-
-    function list_mailboxes($args)
-    {
-        $rcmail = rcmail::get_instance();
-        if (!$rcmail->config->get('use_subscriptions', true)) {
-            $args['folders'] = iil_C_ListMailboxes($rcmail->imap->conn, $rcmail->imap->mod_mailbox($args['root']), $args['filter']);
+            // if the use_subscriptions preference changes, flush the folder cache
+            if (($use_subscriptions && !isset($_POST['_use_subscriptions'])) ||
+                (!$use_subscriptions && isset($_POST['_use_subscriptions']))) {
+                    $storage = $rcmail->get_storage();
+                    $storage->clear_cache('mailboxes');
+            }
         }
         return $args;
     }
 
-    function manage_folders($args)
+    function mailboxes_list($args)
+    {
+        $rcmail  = rcmail::get_instance();
+        if (!$rcmail->config->get('use_subscriptions', true)) {
+            $storage = $rcmail->get_storage();
+            if ($storage->check_connection()) {
+                $args['folders'] = $storage->conn->listMailboxes($args['root'], $args['name']);
+            }
+        }
+        return $args;
+    }
+
+    function folders_list($args)
     {
         $rcmail = rcmail::get_instance();
         if (!$rcmail->config->get('use_subscriptions', true)) {

--
Gitblit v1.9.1