Trying to make both uw and cyrus work with special folders.
[squirrelmail.git] / functions / imap_mailbox.php
index a4936b67812c44ef33bc6f8d220ecf43a17b6298..c221dbd91653792d04c543455a4601f5e03865bf 100755 (executable)
  * $Id$
  */
 
+/*
+    Defines Special Mail Boxes
+*/
+
+function isSpecialMailbox( $box ) {
+
+    global $trash_folder, $sent_folder, $draft_folder,
+           $move_to_trash, $move_to_sent, $save_as_draft,
+           $delimiter, $folder_prefix, $imap_server_type;
+
+    if ( $imap_server_type == 'uw' ) {
+        $boxs = $box;
+        $i = strpos( $sent_folder, $delimiter, strlen( $folder_prefix ) );
+        if ( $i === FALSE ) {
+            $i = strlen( $box );
+        }
+    } else {
+        $boxs = $box . $delimiter;
+        // Skip next second delimiter
+        $i = strpos( $sent_folder, $delimiter );
+        $i = strpos( $sent_folder, $delimiter, $i + 1  );
+        if ( $i === FALSE ) {
+            $i = strlen( $box );
+        } else {
+            $i++;
+        }
+    }
+
+    $ret = ( (strtolower($box) == 'inbox') ||
+             ( substr( $trash_folder, 0, $i ) == substr( $boxs, 0, $i ) &&
+              $move_to_trash) ||
+             ( substr( $sent_folder, 0, $i ) == substr( $boxs, 0, $i ) &&
+              $move_to_sent) ||
+             ($box == $draft_folder &&
+              $save_as_draft) );
+
+    return( $ret );
+
+}
+
 /*************************
  **  Expunges a mailbox **
  *************************/
-function sqimap_mailbox_expunge ($imap_stream, $mailbox,$handle_errors = true)
+function sqimap_mailbox_expunge ($imap_stream, $mailbox,$handle_errors = TRUE)
 {
-    fputs ($imap_stream, sqimap_session_id() . " EXPUNGE\r\n");
-    $read = sqimap_read_data($imap_stream, sqimap_session_id(),
-                             $handle_errors, $response, $message);
+    $read = sqimap_run_command($imap_stream, 'EXPUNGE',
+                               $handle_errors, $response, $message);
 }
 
 
@@ -30,9 +69,8 @@ function sqimap_mailbox_exists ($imap_stream, $mailbox)
     if (! isset($mailbox)) {
         return false;
     }
-    fputs ($imap_stream, sqimap_session_id() . " LIST \"\" \"$mailbox\"\r\n");
-    $mbx = sqimap_read_data($imap_stream, sqimap_session_id(),
-                            true, $response, $message);
+    $mbx = sqimap_run_command($imap_stream, "LIST \"\" \"$mailbox\"",
+                              TRUE, $response, $message);
     return isset($mbx[0]);
 }
 
@@ -40,7 +78,7 @@ function sqimap_mailbox_exists ($imap_stream, $mailbox)
  **  Selects a mailbox
  ******************************************************************************/
 function sqimap_mailbox_select ($imap_stream, $mailbox,
-                                $hide=true, $recent=false)
+                                $hide=TRUE, $recent=false)
 {
     global $auto_expunge;
     
@@ -48,9 +86,8 @@ function sqimap_mailbox_select ($imap_stream, $mailbox,
         return;
     }
     
-    fputs ($imap_stream, sqimap_session_id() . " SELECT \"$mailbox\"\r\n");
-    $read = sqimap_read_data($imap_stream, sqimap_session_id(),
-                             true, $response, $message);
+    $read = sqimap_run_command($imap_stream, "SELECT \"$mailbox\"",
+                               TRUE, $response, $message);
     if ($recent) {
         for ($i=0; $i<count($read); $i++) {
             if (strpos(strtolower($read[$i]), 'recent')) {
@@ -60,9 +97,8 @@ function sqimap_mailbox_select ($imap_stream, $mailbox,
         return $r[1];
     }
     if ($auto_expunge) {
-        fputs ($imap_stream, sqimap_session_id() . " EXPUNGE\r\n");
-        $tmp = sqimap_read_data($imap_stream, sqimap_session_id(),
-                                false, $a, $b);
+        $tmp = sqimap_run_command($imap_stream, 'EXPUNGE',
+                                  false, $a, $b);
     }
 }
 
@@ -77,9 +113,8 @@ function sqimap_mailbox_create ($imap_stream, $mailbox, $type)
     if (strtolower($type) == 'noselect') {
         $mailbox = $mailbox.$delimiter;
     }
-    fputs ($imap_stream, sqimap_session_id() . " CREATE \"$mailbox\"\r\n");
-    $read_ary = sqimap_read_data($imap_stream, sqimap_session_id(),
-                                 true, $response, $message);
+    $read_ary = sqimap_run_command($imap_stream, "CREATE \"$mailbox\"",
+                                   TRUE, $response, $message);
     
     sqimap_subscribe ($imap_stream, $mailbox);
 }
@@ -91,9 +126,8 @@ function sqimap_mailbox_create ($imap_stream, $mailbox, $type)
  ******************************************************************************/
 function sqimap_subscribe ($imap_stream, $mailbox)
 {
-    fputs ($imap_stream, sqimap_session_id() . " SUBSCRIBE \"$mailbox\"\r\n");
-    $read_ary = sqimap_read_data($imap_stream, sqimap_session_id(),
-                                 true, $response, $message);
+    $read_ary = sqimap_run_command($imap_stream, "SUBSCRIBE \"$mailbox\"",
+                                 TRUE, $response, $message);
 }
 
 
@@ -105,9 +139,8 @@ function sqimap_unsubscribe ($imap_stream, $mailbox)
 {
     global $imap_server_type;
     
-    fputs ($imap_stream, sqimap_session_id() . " UNSUBSCRIBE \"$mailbox\"\r\n");
-    $read_ary = sqimap_read_data($imap_stream, sqimap_session_id(),
-                                 true, $response, $message);
+    $read_ary = sqimap_run_command($imap_stream, "UNSUBSCRIBE \"$mailbox\"",
+                                 TRUE, $response, $message);
 }
 
 
@@ -117,9 +150,8 @@ function sqimap_unsubscribe ($imap_stream, $mailbox)
  ******************************************************************************/
 function sqimap_mailbox_delete ($imap_stream, $mailbox)
 {
-    fputs ($imap_stream, sqimap_session_id() . " DELETE \"$mailbox\"\r\n");
-    $read_ary = sqimap_read_data($imap_stream, sqimap_session_id(),
-                                 true, $response, $message);
+    $read_ary = sqimap_run_command($imap_stream, "DELETE \"$mailbox\"",
+                                 TRUE, $response, $message);
     sqimap_unsubscribe ($imap_stream, $mailbox);
 }
 
@@ -131,13 +163,53 @@ function sqimap_mailbox_is_subscribed($imap_stream, $folder)
     $boxes = sqimap_mailbox_list ($imap_stream);
     foreach ($boxes as $ref) {
         if ($ref['unformatted'] == $folder) {
-            return true;
+            return TRUE;
         }
     }
     return false;
 }
 
+/*
+    Renames a mailbox
+*/
+function sqimap_mailbox_rename( $imap_stream, $old_name, $new_name ) {
+
+    if ( $old_name <> $new_name ) {
 
+        global $delimiter;
+
+        if ( substr( $old_name, -1 ) == $delimiter  ) {
+            $old_name = substr( $old_name, 0, strlen( $old_name ) - 1 );
+            $new_name = substr( $new_name, 0, strlen( $new_name ) - 1 );
+            $postfix = $delimiter;
+            $boxes = sqimap_mailbox_list($imap_stream);
+        } else {
+            $postfix = '';
+            $boxes = FALSE;
+        }
+
+        $cmd = 'RENAME "' . quoteIMAP($old_name) . '" "' .  quoteIMAP($new_name) . '"';
+        $data = sqimap_run_command($imap_stream, $cmd,
+                                 TRUE, $response, $message);
+        sqimap_unsubscribe($imap_stream, $old_name.$postfix);
+        sqimap_subscribe($imap_stream, $new_name.$postfix);
+
+        if ( $boxes ) {
+            // Sub-unsub subfolders
+            $l = strlen( $old_name ) + 1;
+            $p = 'unformatted';
+            foreach ( $boxes as $box ) {
+                if ( substr( $box[$p], 0, $l ) == $old_name . $delimiter ) {
+                    sqimap_unsubscribe($imap_stream, $box[$p]);
+                    sqimap_subscribe($imap_stream,
+                                     $new_name . $delimiter . substr( $box[$p], $l ) );
+                }
+            }
+        }
+
+    }
+
+}
 
 /******************************************************************************
  **  Formats a mailbox into 4 parts for the $boxes array
@@ -169,7 +241,7 @@ function sqimap_mailbox_parse ($line, $line_lsub)
         
         /* Count number of delimiters ($delimiter) in folder name */
         $mailbox = trim($line_lsub[$g]);
-        $dm_count = countCharInString($mailbox, $delimiter);
+        $dm_count =  substr_count($mailbox, $delimiter);
         if (substr($mailbox, -1) == $delimiter) {
             /* If name ends in delimiter - decrement count by one */
             $dm_count--;  
@@ -183,19 +255,19 @@ function sqimap_mailbox_parse ($line, $line_lsub)
              (substr($mailbox, 0, strlen($folder_prefix)) == $folder_prefix) ||
              ( isset($boxesbyname[$parentfolder]) &&
                (strlen($parentfolder) > 0) ) ) {
-            $indent = $dm_count - (countCharInString($folder_prefix, $delimiter));
+            $indent = $dm_count - ( substr_count($folder_prefix, $delimiter));
             if ($indent > 0) {
-                $boxes[$g]["formatted"]  = str_repeat("&nbsp;&nbsp;", $indent);
+                $boxes[$g]['formatted']  = str_repeat("&nbsp;&nbsp;", $indent);
             }
             else {
-                $boxes[$g]["formatted"] = '';
+                $boxes[$g]['formatted'] = '';
             }
-            $boxes[$g]["formatted"] .= readShortMailboxName($mailbox, $delimiter);
+            $boxes[$g]['formatted'] .= readShortMailboxName($mailbox, $delimiter);
         }
         else {
-            $boxes[$g]["formatted"]  = $mailbox;
+            $boxes[$g]['formatted']  = $mailbox;
         }
-        
+
         $boxes[$g]['unformatted-dm'] = $mailbox;
         if (substr($mailbox, -1) == $delimiter) {
             $mailbox = substr($mailbox, 0, strlen($mailbox) - 1);
@@ -206,7 +278,7 @@ function sqimap_mailbox_parse ($line, $line_lsub)
         }
         $boxes[$g]['unformatted-disp'] = $mailbox;
         $boxes[$g]['id'] = $g;
-        
+
         $boxes[$g]['flags'] = array();
         if (isset($line[$g])) {
             ereg("\(([^)]*)\)",$line[$g],$regs);
@@ -216,7 +288,7 @@ function sqimap_mailbox_parse ($line, $line_lsub)
             }
         }
     }
-    
+
     return $boxes;
 }
 
@@ -251,9 +323,9 @@ function user_strcasecmp($a, $b) {
         if (($a_del == $delimiter) && ($b_del == $delimiter)) {
             $result = 0;
         } else if (($a_del == $delimiter) && ($b_del != $delimiter)) {
-            $result = 1;
-        } else if (($a_del != $delimiter) && ($b_del != $delimiter)) {
             $result = -1;
+        } else if (($a_del != $delimiter) && ($b_del == $delimiter)) {
+            $result = 1;
         } else {
             $result = strcasecmp($a{$c}, $b{$c});
         }
@@ -262,7 +334,7 @@ function user_strcasecmp($a, $b) {
             break;
         }
     }
-    
+
     /* If one string is a prefix of the other... */
     if ($result == 0) {
         if ($a_length < $b_length) {
@@ -281,32 +353,30 @@ function user_strcasecmp($a, $b) {
  **  See comment on sqimap_mailbox_parse() for info about the returned array.
  ******************************************************************************/
 function sqimap_mailbox_list ($imap_stream) {
-    global $data_dir, $username, $list_special_folders_first;
-    global $folder_prefix, $trash_folder, $sent_folder, $draft_folder;
-    global $move_to_trash, $move_to_sent, $save_as_draft;
-    global $delimiter;
-    
+    global $data_dir, $username, $list_special_folders_first,
+           $folder_prefix, $trash_folder, $sent_folder, $draft_folder,
+           $move_to_trash, $move_to_sent, $save_as_draft,
+           $delimiter;
+
     $inbox_in_list = false;
     $inbox_subscribed = false;
-    
+
     require_once('../src/load_prefs.php');
     require_once('../functions/array.php');
-    
+
     /** LSUB array **/
-    fputs ($imap_stream, sqimap_session_id() .
-           " LSUB \"$folder_prefix\" \"*\"\r\n");
-    $lsub_ary = sqimap_read_data ($imap_stream, sqimap_session_id(),
-                                  true, $response, $message);
-    
+    $lsub_ary = sqimap_run_command ($imap_stream, "LSUB \"$folder_prefix\" \"*\"",
+                                  TRUE, $response, $message);
+
     /* Section about removing the last element was removed */
     /* We don't return "* OK" anymore from sqimap_read_data */
-    
+
     $sorted_lsub_ary = array();
     for ($i=0;$i < count($lsub_ary); $i++) {
         /* Workaround for EIMS */
         /* Doesn't work if the mailbox name is multiple lines */
         if (isset($lsub_ary[$i + 1]) &&
-            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", 
+            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$",
                  $lsub_ary[$i], $regs)) {
             $i ++;
             $lsub_ary[$i] = $regs[1] . '"' . addslashes(trim($lsub_ary[$i])) .
@@ -315,7 +385,7 @@ function sqimap_mailbox_list ($imap_stream) {
         $temp_mailbox_name = find_mailbox_name($lsub_ary[$i]);
         $sorted_lsub_ary[] = $temp_mailbox_name;
         if (strtoupper($temp_mailbox_name) == 'INBOX') {
-            $inbox_subscribed = true;
+            $inbox_subscribed = TRUE;
         }
     }
     $new_ary = array();
@@ -327,8 +397,8 @@ function sqimap_mailbox_list ($imap_stream) {
     $sorted_lsub_ary = $new_ary;
     if (isset($sorted_lsub_ary)) {
         usort($sorted_lsub_ary, 'user_strcasecmp');
-    }   
-    
+    }
+
     /** LIST array **/
     $sorted_list_ary = array();
     for ($i=0; $i < count($sorted_lsub_ary); $i++) {
@@ -338,224 +408,190 @@ function sqimap_mailbox_list ($imap_stream) {
         else {
             $mbx = $sorted_lsub_ary[$i];
         }
-        
-        fputs ($imap_stream, sqimap_session_id() . " LIST \"\" \"$mbx\"\r\n");
-        $read = sqimap_read_data ($imap_stream, sqimap_session_id(),
-                                  true, $response, $message);
+
+        $read = sqimap_run_command ($imap_stream, "LIST \"\" \"$mbx\"",
+                                  TRUE, $response, $message);
         /* Another workaround for EIMS */
-        if (isset($read[1]) && 
-            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", 
+        if (isset($read[1]) &&
+            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$",
                  $read[0], $regs)) {
             $read[0] = $regs[1] . '"' . addslashes(trim($read[1])) .
-                '"' . $regs[2];
+                       '"' . $regs[2];
         }
-        
+
         if (isset($sorted_list_ary[$i])) {
-            $sorted_list_ary[$i] = "";
+            $sorted_list_ary[$i] = '';
         }
-        
+
         if (isset($read[0])) {
             $sorted_list_ary[$i] = $read[0];
         }
         else {
-            $sorted_list_ary[$i] = "";
+            $sorted_list_ary[$i] = '';
         }
-        
-        if (isset($sorted_list_ary[$i]) && 
-            strtoupper(find_mailbox_name($sorted_list_ary[$i])) == "INBOX") {
-            $inbox_in_list = true;
+
+        if (isset($sorted_list_ary[$i]) &&
+            strtoupper(find_mailbox_name($sorted_list_ary[$i])) == 'INBOX') {
+            $inbox_in_list = TRUE;
         }
     }
-    
+
     /**
      * Just in case they're not subscribed to their inbox,
      * we'll get it for them anyway
      */
     if ($inbox_subscribed == false || $inbox_in_list == false) {
-        fputs ($imap_stream, sqimap_session_id() . " LIST \"\" \"INBOX\"\r\n");
-        $inbox_ary = sqimap_read_data ($imap_stream, sqimap_session_id(),
-                                       true, $response, $message);
+        $inbox_ary = sqimap_run_command ($imap_stream, "LIST \"\" \"INBOX\"",
+                                       TRUE, $response, $message);
         /* Another workaround for EIMS */
         if (isset($inbox_ary[1]) &&
-            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", 
+            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$",
                  $inbox_ary[0], $regs)) {
             $inbox_ary[0] = $regs[1] . '"' . addslashes(trim($inbox_ary[1])) .
                 '"' . $regs[2];
         }
-        
+
         $sorted_list_ary[] = $inbox_ary[0];
         $sorted_lsub_ary[] = find_mailbox_name($inbox_ary[0]);
     }
-    
+
     $boxes = sqimap_mailbox_parse ($sorted_list_ary, $sorted_lsub_ary);
-    
+
     /** Now, lets sort for special folders **/
-    $boxesnew = Array();
-    
+    $boxesnew = $used = array();
+
     /* Find INBOX */
-    for ($i = 0; $i < count($boxes); $i++) {
-        if (strtolower($boxes[$i]["unformatted"]) == "inbox") {
-            $boxesnew[] = $boxes[$i];
-            $used[$i] = true;
-            $i = count($boxes);
+    foreach ( $boxes as $k => $box ) {
+        if ( strtolower($box['unformatted']) == 'inbox') {
+            $boxesnew[] = $box;
+            $used[$k] = TRUE;
+        } else {
+            $used[$k] = FALSE;
         }
     }
-    
+
     /* List special folders and their subfolders, if requested. */
-    if ($list_special_folders_first == true) {
-        /* First list the trash folder. */
-        for ($i = 0 ; $i < count($boxes) ; $i++) {
-            if ($move_to_trash &&
-                eregi('^' . quotemeta($trash_folder) . '(' .
-                      quotemeta($delimiter) . '.*)?$', $boxes[$i]['unformatted'])) {
-                $boxesnew[] = $boxes[$i];
-                $used[$i] = true;
-            }
-        }
-        
-        /* Then list the sent folder. */
-        for ($i = 0 ; $i < count($boxes) ; $i++) {
-            if ($move_to_sent &&
-                eregi('^' . quotemeta($sent_folder) . '(' .
-                      quotemeta($delimiter) . '.*)?$', $boxes[$i]['unformatted'])) {
-                $boxesnew[] = $boxes[$i];
-                $used[$i] = true;
-            }
-        }
-        
-        /* Lastly, list the list the draft folder. */
-        for ($i = 0 ; $i < count($boxes) ; $i++) {
-            if ($save_as_draft &&
-                eregi('^' . quotemeta($draft_folder) . '(' .
-                      quotemeta($delimiter) . '.*)?$', $boxes[$i]['unformatted'])) {
-                $boxesnew[] = $boxes[$i];
-                $used[$i] = true;
-            }
-        }
-        
-        /* Put INBOX.* folders ahead of the rest. */
-        for ($i = 0; $i < count($boxes); $i++) {
-            if (eregi('^inbox\\.', $boxes[$i]["unformatted"]) &&
-                (!isset($used[$i]) || $used[$i] == false)) {
-                $boxesnew[] = $boxes[$i];
-                $used[$i] = true;
+    if ($list_special_folders_first == TRUE) {
+
+        foreach ( $boxes as $k => $box ) {
+            if ( !$used[$k] &&
+                 isSpecialMailbox( $box['unformatted'] ) ) {
+                $boxesnew[] = $box;
+                $used[$k] = TRUE;
             }
         }
+
     }
-    
+
     /* Rest of the folders */
-    for ($i = 0; $i < count($boxes); $i++) {
-        if ((strtolower($boxes[$i]["unformatted"]) != "inbox") &&
-            (!isset($used[$i]) || $used[$i] == false))  {
-            $boxesnew[] = $boxes[$i];
-            $used[$i] = true;
+    foreach ( $boxes as $k => $box ) {
+        if ( !$used[$k] ) {
+            $boxesnew[] = $box;
         }
     }
-    
-    return $boxesnew;
+
+    return( $boxesnew );
 }
 
-/******************************************************************************
- **  Returns a list of all folders, subscribed or not
- ******************************************************************************/
+/*
+ *  Returns a list of all folders, subscribed or not
+ */
 function sqimap_mailbox_list_all ($imap_stream)
 {
     global $list_special_folders_first, $folder_prefix;
     global $delimiter;
-    
-    if (!function_exists ("ary_sort")) {
+
+    if (!function_exists('ary_sort')) {
         include_once('../functions/array.php');
     }
-    
+
     $ssid = sqimap_session_id();
-    $lsid = strlen( $ssid ); 
+    $lsid = strlen( $ssid );
     fputs ($imap_stream, $ssid . " LIST \"$folder_prefix\" *\r\n");
-    $read_ary = sqimap_read_data ($imap_stream, $ssid, true, $response, $message);
+    $read_ary = sqimap_read_data ($imap_stream, $ssid, TRUE, $response, $message);
     $g = 0;
-    $phase = "inbox";
-    
+    $phase = 'inbox';
+
     for ($i = 0; $i < count($read_ary); $i++) {
         /* Another workaround for EIMS */
         if (isset($read_ary[$i + 1]) &&
-            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", 
+            ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$",
                  $read_ary[$i], $regs)) {
             $i ++;
-            $read_ary[$i] = $regs[1] . '"' . 
-                           addslashes(trim($read_ary[$i])) .
-                           '"' . $regs[2];
+            $read_ary[$i] = $regs[1] . '"' .
+                            addslashes(trim($read_ary[$i])) .
+                            '"' . $regs[2];
         }
-        if (substr ($read_ary[$i], 0, $lsid) != $ssid ) {
-            
+        if (substr($read_ary[$i], 0, $lsid) != $ssid ) {
+
             /* Store the raw IMAP reply */
             $boxes[$g]["raw"] = $read_ary[$i];
-            
+
             /* Count number of delimiters ($delimiter) in folder name */
             $mailbox = find_mailbox_name($read_ary[$i]);
-            $dm_count = countCharInString($mailbox, $delimiter);
+            $dm_count =  substr_count($mailbox, $delimiter);
             if (substr($mailbox, -1) == $delimiter) {
                 /* If name ends in delimiter - decrement count by one */
-                $dm_count--;  
+                $dm_count--;
             }
-            
+
             /* Format folder name, but only if it's a INBOX.* or have */
             /* a parent. */
             $boxesbyname[$mailbox] = $g;
             $parentfolder = readMailboxParent($mailbox, $delimiter);
-            if((eregi('^inbox'.quotemeta($delimiter), $mailbox)) || 
+            if((eregi('^inbox'.quotemeta($delimiter), $mailbox)) ||
                (ereg('^'.$folder_prefix, $mailbox)) ||
                ( isset($boxesbyname[$parentfolder]) && (strlen($parentfolder) > 0) ) ) {
                 if ($dm_count) {
-                    $boxes[$g]["formatted"]  = str_repeat("&nbsp;&nbsp;", $dm_count);
+                    $boxes[$g]['formatted']  = str_repeat('&nbsp;&nbsp;', $dm_count);
                 }
                 else {
-                    $boxes[$g]["formatted"] = '';
+                    $boxes[$g]['formatted'] = '';
                 }
-                $boxes[$g]["formatted"] .= readShortMailboxName($mailbox, $delimiter);
+                $boxes[$g]['formatted'] .= readShortMailboxName($mailbox, $delimiter);
             }
             else {
-                $boxes[$g]["formatted"]  = $mailbox;
+                $boxes[$g]['formatted']  = $mailbox;
             }
-            
+
             $boxes[$g]["unformatted-dm"] = $mailbox;
             if (substr($mailbox, -1) == $delimiter) {
                 $mailbox = substr($mailbox, 0, strlen($mailbox) - 1);
             }
-            $boxes[$g]["unformatted"] = $mailbox;
-            $boxes[$g]["unformatted-disp"] =
+            $boxes[$g]['unformatted'] = $mailbox;
+            $boxes[$g]['unformatted-disp'] =
                 ereg_replace('^' . $folder_prefix, '', $mailbox);
-            $boxes[$g]["id"] = $g;
-            
+            $boxes[$g]['id'] = $g;
+
             /** Now lets get the flags for this mailbox **/
-            fputs ($imap_stream, sqimap_session_id() . " LIST \"\" \"$mailbox\"\r\n");
-            $read_mlbx = sqimap_read_data ($imap_stream, sqimap_session_id(),
-                                           true, $response, $message);
-            
+            $read_mlbx = sqimap_run_command ($imap_stream, "LIST \"\" \"$mailbox\"",
+                                           TRUE, $response, $message);
+
             /* Another workaround for EIMS */
             if (isset($read_mlbx[1]) &&
-                ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$", 
+                ereg("^(\\* [A-Z]+.*)\\{[0-9]+\\}([ \n\r\t]*)$",
                      $read_mlbx[0], $regs)) {
-                $read_mlbx[0] = $regs[1] . '"' . 
-                                   addslashes(trim($read_mlbx[1])) .
-                                   '"' . $regs[2];
+                $read_mlbx[0] = $regs[1] . '"' .
+                                addslashes(trim($read_mlbx[1])) .
+                                '"' . $regs[2];
             }
-            
-            $flags = substr($read_mlbx[0], strpos($read_mlbx[0], "(")+1);
-            $flags = substr($flags, 0, strpos($flags, ")"));
+
+            $flags = substr($read_mlbx[0], strpos($read_mlbx[0], '(')+1);
+            $flags = substr($flags, 0, strpos($flags, ')'));
             $flags = str_replace('\\', '', $flags);
             $flags = trim(strtolower($flags));
             if ($flags) {
-                $boxes[$g]['flags'] = explode(" ", $flags);
-            }
-            else {
+                $boxes[$g]['flags'] = explode(' ', $flags);
+            } else {
                 $boxes[$g]['flags'] = array();
             }
         }
         $g++;
     }
     if(is_array($boxes)) {
-        $boxes = ary_sort ($boxes, "unformatted", 1);
+        $boxes = ary_sort ($boxes, 'unformatted', 1);
     }
-    
+
     return $boxes;
 }