From c0c512aa7de8ca5a4f98b78774d6ee76c896999d Mon Sep 17 00:00:00 2001 From: Steven Ngesera Date: Tue, 22 Oct 2024 18:20:05 +0300 Subject: [PATCH] [FIX] Fixed jmap quota display --- modules/imap/handler_modules.php | 34 ++++++++++++++++++++++++-------- modules/imap/hm-jmap.php | 27 +++++++++++++++++++++++-- 2 files changed, 51 insertions(+), 10 deletions(-) diff --git a/modules/imap/handler_modules.php b/modules/imap/handler_modules.php index d418cb502d..b5a54119c6 100644 --- a/modules/imap/handler_modules.php +++ b/modules/imap/handler_modules.php @@ -750,14 +750,32 @@ public function process() { $this->out('can_share_folders', stripos($imap->get_capability(), 'ACL') !== false); if (imap_authed($imap)) { $quota_root = $imap->get_quota_root($folder ? $folder : 'INBOX'); - if ($quota_root && isset($quota_root[0]['name'])) { - $quota = $imap->get_quota($quota_root[0]['name']); - if ($quota) { - $current = floatval($quota[0]['current']); - $max = floatval($quota[0]['max']); - if ($max > 0) { - $this->out('quota', ceil(($current / $max) * 100)); - $this->out('quota_max', $max / 1024); + if($imap instanceof Hm_JMAP) { + if (!empty($quota_root["methodResponses"][0][1]["list"])) { + $quota = $quota_root["methodResponses"][0][1]["list"][0]; + + if ($quota) { + $used = floatval($quota['used']); + $max = floatval($quota['hardLimit']); + if ($max > 0) { + $quotaPercentage = ceil(($used / $max) * 100); + $quotaMaxInMB = $max / (1024 * 1024); + + $this->out('quota', $quotaPercentage); + $this->out('quota_max', $quotaMaxInMB); + } + } + } + }else { + if ($quota_root && isset($quota_root[0]['name'])) { + $quota = $imap->get_quota($quota_root[0]['name']); + if ($quota) { + $current = floatval($quota[0]['current']); + $max = floatval($quota[0]['max']); + if ($max > 0) { + $this->out('quota', ceil(($current / $max) * 100)); + $this->out('quota_max', $max / 1024); + } } } } diff --git a/modules/imap/hm-jmap.php b/modules/imap/hm-jmap.php index 46b28040e9..4c6121431f 100644 --- a/modules/imap/hm-jmap.php +++ b/modules/imap/hm-jmap.php @@ -69,7 +69,8 @@ class Hm_JMAP { ); private $default_caps = array( 'urn:ietf:params:jmap:core', - 'urn:ietf:params:jmap:mail' + 'urn:ietf:params:jmap:mail', + 'urn:ietf:params:jmap:quota' ); public $selected_mailbox; @@ -376,6 +377,28 @@ public function get_folder_list_by_level($level=false) { return $this->parse_folder_list_by_level($level); } + public function get_quota_root($mailbox) { + if (!is_array($this->session)) { + throw new Exception("Not authenticated. Please authenticate first."); + } + $methods = [ + [ + "Quota/get", + [ + "accountId"=> (string)$this->account_id, + "name" => $this->session['username'], + "scope" => "folder", + "folder" => $mailbox + ], + "0" + ] + ]; + $response = $this->send_command($this->session['apiUrl'], $methods, 'POST'); + return $response; + } + public function get_capability() { + //TODO: Implement + } /** * Return cached data * @return array @@ -452,7 +475,7 @@ public function get_folder_list() { $methods = array(array( 'Mailbox/get', array( - 'accountId' => $this->account_id, + 'accountId' => (string)$this->account_id, 'ids' => NULL ), 'fl'