zm-ruby-client 2.2.7 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.rubocop.yml +6 -0
- data/.ruby-version +1 -0
- data/CHANGELOG.md +10 -6
- data/Gemfile +1 -6
- data/README.md +10 -15
- data/VERSION +1 -1
- data/lib/zm/client/account/account.rb +35 -22
- data/lib/zm/client/account/account_aliases_collection.rb +14 -6
- data/lib/zm/client/account/account_dls_membership_collection.rb +10 -4
- data/lib/zm/client/account/account_dls_owner_collection.rb +8 -5
- data/lib/zm/client/account/account_jsns_builder.rb +31 -19
- data/lib/zm/client/account/account_jsns_initializer.rb +4 -14
- data/lib/zm/client/account/accounts_builder.rb +1 -1
- data/lib/zm/client/account/accounts_collection.rb +15 -8
- data/lib/zm/client/ace/ace.rb +5 -5
- data/lib/zm/client/ace/ace_jsns_builder.rb +8 -8
- data/lib/zm/client/ace/ace_jsns_initializer.rb +7 -7
- data/lib/zm/client/ace/aces_builder.rb +1 -1
- data/lib/zm/client/ace/aces_collection.rb +2 -2
- data/lib/zm/client/appointment/appointment.rb +27 -24
- data/lib/zm/client/appointment/appointment_jsns_builder.rb +29 -20
- data/lib/zm/client/appointment/appointment_jsns_initializer.rb +14 -13
- data/lib/zm/client/appointment/appointments_builder.rb +1 -1
- data/lib/zm/client/appointment/appointments_collection.rb +8 -7
- data/lib/zm/client/backup/backup.rb +6 -2
- data/lib/zm/client/backup/backup_jsns_initializer.rb +14 -12
- data/lib/zm/client/backup/backups_builder.rb +1 -1
- data/lib/zm/client/backup/backups_collection.rb +2 -1
- data/lib/zm/client/base/account_search_objects_collection.rb +46 -20
- data/lib/zm/client/base/admin_objects_collection.rb +22 -27
- data/lib/zm/client/base/base_account_jsns_builder.rb +1 -4
- data/lib/zm/client/base/base_jsns_initializer.rb +8 -8
- data/lib/zm/client/base/mailbox_infos_collection.rb +23 -15
- data/lib/zm/client/base/mailbox_object.rb +174 -69
- data/lib/zm/client/base/mailbox_prefs_collection.rb +4 -8
- data/lib/zm/client/base/object.rb +2 -2
- data/lib/zm/client/base/objects_builder.rb +7 -3
- data/lib/zm/client/base/objects_collection.rb +4 -13
- data/lib/zm/client/base/zimbra_attribute.rb +4 -17
- data/lib/zm/client/base/zimbra_attributes_collection.rb +16 -9
- data/lib/zm/client/base.rb +0 -1
- data/lib/zm/client/cluster/batch_request.rb +50 -0
- data/lib/zm/client/cluster/cluster.rb +49 -27
- data/lib/zm/client/cluster/cluster_config.rb +129 -40
- data/lib/zm/client/common/recipients.rb +2 -2
- data/lib/zm/client/common/utils.rb +1 -13
- data/lib/zm/client/common.rb +0 -1
- data/lib/zm/client/connector/{rest_account.rb → rest_connector.rb} +40 -50
- data/lib/zm/client/connector/soap_account.rb +19 -15
- data/lib/zm/client/connector/soap_admin.rb +9 -9
- data/lib/zm/client/connector/soap_base.rb +24 -17
- data/lib/zm/client/connector/soap_error.rb +3 -23
- data/lib/zm/client/constant.rb +18 -16
- data/lib/zm/client/contact/contact.rb +21 -40
- data/lib/zm/client/contact/contact_jsns_builder.rb +1 -1
- data/lib/zm/client/contact/contact_jsns_initializer.rb +4 -26
- data/lib/zm/client/contact/contacts_builder.rb +1 -1
- data/lib/zm/client/contact/contacts_collection.rb +4 -24
- data/lib/zm/client/contact/group_contact_jsns_builder.rb +18 -13
- data/lib/zm/client/contact/mod_group_contact.rb +6 -2
- data/lib/zm/client/cos/cos.rb +35 -11
- data/lib/zm/client/cos/cos_domains_collection.rb +1 -1
- data/lib/zm/client/cos/cos_jsns_builder.rb +22 -9
- data/lib/zm/client/cos/cos_jsns_initializer.rb +2 -6
- data/lib/zm/client/cos/cos_servers_collection.rb +5 -6
- data/lib/zm/client/cos/coses_builder.rb +1 -1
- data/lib/zm/client/cos/coses_collection.rb +6 -4
- data/lib/zm/client/datasource/datasource.rb +27 -34
- data/lib/zm/client/datasource/datasource_jsns_builder.rb +1 -1
- data/lib/zm/client/datasource/datasource_jsns_initializer.rb +5 -6
- data/lib/zm/client/datasource/datasources_builder.rb +6 -9
- data/lib/zm/client/datasource/datasources_collection.rb +6 -5
- data/lib/zm/client/distributionlist/distributionlist.rb +22 -42
- data/lib/zm/client/distributionlist/distributionlist_aliases_collection.rb +14 -6
- data/lib/zm/client/distributionlist/distributionlist_jsns_builder.rb +20 -16
- data/lib/zm/client/distributionlist/distributionlist_jsns_initializer.rb +2 -11
- data/lib/zm/client/distributionlist/distributionlist_members_collection.rb +20 -12
- data/lib/zm/client/distributionlist/distributionlist_owners_collection.rb +16 -5
- data/lib/zm/client/distributionlist/distributionlists_builder.rb +1 -1
- data/lib/zm/client/distributionlist/distributionlists_collection.rb +12 -6
- data/lib/zm/client/distributionlist/dls_membership_collection.rb +12 -6
- data/lib/zm/client/document/document.rb +16 -8
- data/lib/zm/client/document/document_jsns_builder.rb +1 -1
- data/lib/zm/client/document/document_jsns_initializer.rb +27 -26
- data/lib/zm/client/document/documents_builder.rb +1 -1
- data/lib/zm/client/document/documents_collection.rb +1 -1
- data/lib/zm/client/domain/domain.rb +18 -37
- data/lib/zm/client/domain/domain_accounts_collection.rb +1 -1
- data/lib/zm/client/domain/domain_distributionlists_collection.rb +1 -1
- data/lib/zm/client/domain/domain_jsns_builder.rb +18 -9
- data/lib/zm/client/domain/domain_jsns_initializer.rb +2 -6
- data/lib/zm/client/domain/domain_resources_collection.rb +1 -1
- data/lib/zm/client/domain/domains_builder.rb +1 -1
- data/lib/zm/client/domain/domains_collection.rb +12 -6
- data/lib/zm/client/filter_rules/filter_rule.rb +0 -9
- data/lib/zm/client/filter_rules/filter_rule_jsns_initializer.rb +7 -6
- data/lib/zm/client/filter_rules/filter_rules_builder.rb +1 -1
- data/lib/zm/client/filter_rules/filter_rules_collection.rb +5 -15
- data/lib/zm/client/filter_rules/outgoing_filter_rules_collection.rb +5 -2
- data/lib/zm/client/folder/folder.rb +73 -56
- data/lib/zm/client/folder/folder_grant.rb +7 -5
- data/lib/zm/client/folder/folder_grant_jsns_builder.rb +6 -3
- data/lib/zm/client/folder/folder_grants_collection.rb +2 -4
- data/lib/zm/client/folder/folder_jsns_builder.rb +14 -7
- data/lib/zm/client/folder/folder_jsns_initializer.rb +58 -40
- data/lib/zm/client/folder/folder_retention_policies_collection.rb +4 -2
- data/lib/zm/client/folder/folders_builder.rb +1 -1
- data/lib/zm/client/folder/folders_collection.rb +21 -18
- data/lib/zm/client/folder/folders_jsns_builder.rb +4 -2
- data/lib/zm/client/folder/mod_document_folder.rb +5 -4
- data/lib/zm/client/identity/identities_builder.rb +1 -1
- data/lib/zm/client/identity/identities_collection.rb +6 -5
- data/lib/zm/client/identity/identity.rb +9 -29
- data/lib/zm/client/identity/identity_jsns_builder.rb +8 -4
- data/lib/zm/client/identity/identity_jsns_initializer.rb +5 -4
- data/lib/zm/client/license/license.rb +7 -1
- data/lib/zm/client/license/license_jsns_initializer.rb +8 -5
- data/lib/zm/client/license/licenses_collection.rb +1 -1
- data/lib/zm/client/mailbox/mailbox_item_concern.rb +33 -0
- data/lib/zm/client/mailbox/mailbox_item_id.rb +7 -0
- data/lib/zm/client/message/attachments_collection.rb +2 -2
- data/lib/zm/client/message/message.rb +56 -52
- data/lib/zm/client/message/message_flags.rb +21 -13
- data/lib/zm/client/message/message_jsns_builder.rb +11 -6
- data/lib/zm/client/message/message_jsns_initializer.rb +24 -23
- data/lib/zm/client/message/messages_builder.rb +1 -1
- data/lib/zm/client/message/messages_collection.rb +1 -15
- data/lib/zm/client/mountpoint/mountpoint.rb +17 -25
- data/lib/zm/client/mountpoint/mountpoint_jsns_builder.rb +6 -3
- data/lib/zm/client/mountpoint/mountpoint_jsns_initializer.rb +25 -24
- data/lib/zm/client/mountpoint/mountpoints_builder.rb +1 -1
- data/lib/zm/client/mountpoint/mountpoints_collection.rb +13 -9
- data/lib/zm/client/mta_queue/mta_queue.rb +6 -2
- data/lib/zm/client/mta_queue/mta_queue_jsns_initializer.rb +3 -7
- data/lib/zm/client/mta_queue/mta_queues_builder.rb +3 -1
- data/lib/zm/client/mta_queue_item/mta_queue_item.rb +5 -3
- data/lib/zm/client/mta_queue_item/mta_queue_item_jsns_initializer.rb +1 -5
- data/lib/zm/client/mta_queue_item/mta_queue_items_builder.rb +3 -1
- data/lib/zm/client/mta_queue_item/mta_queue_items_collection.rb +3 -1
- data/lib/zm/client/resource/resource.rb +6 -18
- data/lib/zm/client/resource/resource_jsns_builder.rb +20 -13
- data/lib/zm/client/resource/resource_jsns_initializer.rb +4 -14
- data/lib/zm/client/resource/resources_builder.rb +1 -1
- data/lib/zm/client/resource/resources_collection.rb +12 -7
- data/lib/zm/client/search_folder/search_folder.rb +13 -29
- data/lib/zm/client/search_folder/search_folder_jsns_builder.rb +6 -6
- data/lib/zm/client/search_folder/search_folder_jsns_initializer.rb +19 -18
- data/lib/zm/client/search_folder/search_folders_builder.rb +1 -1
- data/lib/zm/client/search_folder/search_folders_collection.rb +6 -5
- data/lib/zm/client/server/server.rb +9 -3
- data/lib/zm/client/server/server_accounts_collection.rb +4 -2
- data/lib/zm/client/server/server_jsns_initializer.rb +1 -5
- data/lib/zm/client/server/servers_builder.rb +1 -1
- data/lib/zm/client/server/servers_collection.rb +17 -9
- data/lib/zm/client/share/share.rb +5 -3
- data/lib/zm/client/share/share_jsns_initializer.rb +15 -14
- data/lib/zm/client/share/share_mountpoints_collection.rb +3 -6
- data/lib/zm/client/share/shares_builder.rb +1 -1
- data/lib/zm/client/share/shares_collection.rb +6 -3
- data/lib/zm/client/signature/signature.rb +6 -21
- data/lib/zm/client/signature/signature_jsns_builder.rb +12 -7
- data/lib/zm/client/signature/signature_jsns_initializer.rb +5 -4
- data/lib/zm/client/signature/signatures_builder.rb +1 -1
- data/lib/zm/client/signature/signatures_collection.rb +6 -5
- data/lib/zm/client/soap_request/request_methods_admin.rb +56 -0
- data/lib/zm/client/soap_request/request_methods_mailbox.rb +60 -0
- data/lib/zm/client/soap_request/soap_constants.rb +7 -0
- data/lib/zm/client/soap_request/soap_context.rb +11 -2
- data/lib/zm/client/soap_request.rb +3 -0
- data/lib/zm/client/tag/account_object_tags_collection.rb +11 -9
- data/lib/zm/client/tag/tag.rb +8 -44
- data/lib/zm/client/tag/tag_jsns_builder.rb +4 -2
- data/lib/zm/client/tag/tag_jsns_initializer.rb +7 -6
- data/lib/zm/client/tag/tags_builder.rb +1 -1
- data/lib/zm/client/tag/tags_collection.rb +6 -5
- data/lib/zm/client/task/task.rb +6 -5
- data/lib/zm/client/task/task_jsns_initializer.rb +28 -27
- data/lib/zm/client/task/tasks_builder.rb +1 -1
- data/lib/zm/client/task/tasks_collection.rb +2 -2
- data/lib/zm/client/token.rb +52 -0
- data/lib/zm/client/upload/upload.rb +101 -95
- data/lib/zm/client/zm_logger.rb +83 -0
- data/lib/zm/client.rb +6 -1
- data/lib/zm/modules/base.rb +0 -1
- data/lib/zm/modules/belongs_to_folder.rb +6 -7
- data/lib/zm/modules/belongs_to_tag.rb +3 -1
- data/lib/zm/modules/common/zimbra-attrs.csv +3 -4
- data/lib/zm/modules/inspector.rb +2 -2
- data/lib/zm/modules/missing_method_static_collection.rb +2 -2
- data/lib/zm/support/cache/entry.rb +63 -0
- data/lib/zm/support/cache/file_store.rb +141 -0
- data/lib/zm/support/cache/null_store.rb +43 -0
- data/lib/zm/support/cache/request_strategy.rb +10 -0
- data/lib/zm/support/cache/store.rb +197 -0
- data/lib/zm/support/cache/strategy.rb +13 -0
- data/lib/zm/support/cache.rb +26 -0
- data/lib/zm-ruby-client.rb +2 -2
- data/zm-ruby-client.gemspec +10 -15
- metadata +37 -36
- data/lib/zm/client/common/token_metadata.rb +0 -44
- data/lib/zm/modules/zm_logger.rb +0 -26
|
@@ -9,11 +9,9 @@ module Zm
|
|
|
9
9
|
end
|
|
10
10
|
|
|
11
11
|
def all
|
|
12
|
-
@all
|
|
13
|
-
end
|
|
12
|
+
return @all if defined? @all
|
|
14
13
|
|
|
15
|
-
|
|
16
|
-
@all = @parent.tn.split(',')
|
|
14
|
+
@all = @parent.tn.to_s.split(',')
|
|
17
15
|
end
|
|
18
16
|
|
|
19
17
|
def add!(*new_tags)
|
|
@@ -31,8 +29,8 @@ module Zm
|
|
|
31
29
|
do_action(attrs)
|
|
32
30
|
end
|
|
33
31
|
|
|
34
|
-
@
|
|
35
|
-
|
|
32
|
+
@all += new_tags
|
|
33
|
+
update_parent
|
|
36
34
|
end
|
|
37
35
|
|
|
38
36
|
def remove!(*tag_names)
|
|
@@ -50,8 +48,12 @@ module Zm
|
|
|
50
48
|
do_action(attrs)
|
|
51
49
|
end
|
|
52
50
|
|
|
53
|
-
@
|
|
54
|
-
|
|
51
|
+
@all -= tag_names
|
|
52
|
+
update_parent
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
def update_parent
|
|
56
|
+
@parent.tn = @all.join(',')
|
|
55
57
|
end
|
|
56
58
|
|
|
57
59
|
def do_action(attrs)
|
|
@@ -59,7 +61,7 @@ module Zm
|
|
|
59
61
|
node_action = SoapElement.create(SoapConstants::ACTION).add_attributes(attrs)
|
|
60
62
|
soap_request.add_node(node_action)
|
|
61
63
|
|
|
62
|
-
@parent.parent.
|
|
64
|
+
@parent.parent.soap_connector.invoke(soap_request)
|
|
63
65
|
end
|
|
64
66
|
end
|
|
65
67
|
end
|
data/lib/zm/client/tag/tag.rb
CHANGED
|
@@ -4,60 +4,24 @@ module Zm
|
|
|
4
4
|
module Client
|
|
5
5
|
# class account tag
|
|
6
6
|
class Tag < Base::Object
|
|
7
|
-
|
|
7
|
+
include RequestMethodsMailbox
|
|
8
|
+
include MailboxItemConcern
|
|
8
9
|
|
|
9
|
-
attr_accessor :
|
|
10
|
-
|
|
11
|
-
# define_changed_attributes :name, :color, :rgb
|
|
10
|
+
attr_accessor :name, :color, :rgb
|
|
12
11
|
|
|
13
12
|
def create!
|
|
14
|
-
rep = @parent.
|
|
13
|
+
rep = @parent.soap_connector.invoke(build_create)
|
|
15
14
|
json = rep[:CreateTagResponse][:tag].first
|
|
16
15
|
TagJsnsInitializer.update(self, json)
|
|
17
|
-
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
def modify!
|
|
21
|
-
# return unless color_changed? || rgb_changed?
|
|
22
|
-
|
|
23
|
-
@parent.sacc.invoke(jsns_builder.to_update)
|
|
24
|
-
true
|
|
25
|
-
end
|
|
26
|
-
|
|
27
|
-
def update!(hash)
|
|
28
|
-
return false if hash.delete_if { |k, v| v.nil? || !respond_to?(k) }.empty?
|
|
29
|
-
|
|
30
|
-
do_update!(hash)
|
|
31
|
-
|
|
32
|
-
hash.each do |key, value|
|
|
33
|
-
update_attribute(key, value)
|
|
34
|
-
end
|
|
35
|
-
|
|
36
|
-
true
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
def rename!(new_name)
|
|
40
|
-
return false if new_name == @name
|
|
41
|
-
|
|
42
|
-
@parent.sacc.invoke(jsns_builder.to_rename(new_name))
|
|
43
|
-
@name = new_name
|
|
44
|
-
end
|
|
45
|
-
|
|
46
|
-
def delete!
|
|
47
|
-
return false if @id.nil?
|
|
48
|
-
|
|
49
|
-
@parent.sacc.invoke(jsns_builder.to_delete)
|
|
50
|
-
@id = nil
|
|
16
|
+
id
|
|
51
17
|
end
|
|
52
18
|
|
|
53
19
|
private
|
|
54
20
|
|
|
55
|
-
def do_update!(hash)
|
|
56
|
-
@parent.sacc.invoke(jsns_builder.to_patch(hash))
|
|
57
|
-
end
|
|
58
|
-
|
|
59
21
|
def jsns_builder
|
|
60
|
-
@jsns_builder
|
|
22
|
+
return @jsns_builder if defined? @jsns_builder
|
|
23
|
+
|
|
24
|
+
@jsns_builder = TagJsnsBuilder.new(self)
|
|
61
25
|
end
|
|
62
26
|
end
|
|
63
27
|
end
|
|
@@ -9,7 +9,8 @@ module Zm
|
|
|
9
9
|
name: @item.name,
|
|
10
10
|
color: @item.color,
|
|
11
11
|
rgb: @item.rgb
|
|
12
|
-
}
|
|
12
|
+
}
|
|
13
|
+
attrs.compact!
|
|
13
14
|
|
|
14
15
|
soap_request = SoapElement.mail(SoapMailConstants::CREATE_TAG_REQUEST)
|
|
15
16
|
node_tag = SoapElement.create(SoapConstants::TAG).add_attributes(attrs)
|
|
@@ -25,7 +26,8 @@ module Zm
|
|
|
25
26
|
id: @item.id,
|
|
26
27
|
color: @item.color,
|
|
27
28
|
rgb: @item.rgb
|
|
28
|
-
}
|
|
29
|
+
}
|
|
30
|
+
attrs.compact!
|
|
29
31
|
|
|
30
32
|
build(attrs)
|
|
31
33
|
end
|
|
@@ -6,15 +6,16 @@ module Zm
|
|
|
6
6
|
class TagJsnsInitializer
|
|
7
7
|
class << self
|
|
8
8
|
def create(parent, json)
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
Tag.new(parent).tap do |item|
|
|
10
|
+
update(item, json)
|
|
11
|
+
end
|
|
11
12
|
end
|
|
12
13
|
|
|
13
14
|
def update(item, json)
|
|
14
|
-
item.id = json
|
|
15
|
-
item.name = json
|
|
16
|
-
item.color = json
|
|
17
|
-
item.rgb = json
|
|
15
|
+
item.id = json.delete(:id)
|
|
16
|
+
item.name = json.delete(:name)
|
|
17
|
+
item.color = json.delete(:color)
|
|
18
|
+
item.rgb = json.delete(:rgb)
|
|
18
19
|
|
|
19
20
|
item
|
|
20
21
|
end
|
|
@@ -7,14 +7,15 @@ module Zm
|
|
|
7
7
|
def initialize(parent)
|
|
8
8
|
@child_class = Tag
|
|
9
9
|
@builder_class = TagBuilder
|
|
10
|
-
super
|
|
10
|
+
super
|
|
11
11
|
end
|
|
12
12
|
|
|
13
|
-
private
|
|
14
|
-
|
|
15
13
|
def make_query
|
|
16
|
-
|
|
17
|
-
|
|
14
|
+
@parent.soap_connector.invoke(build_query)
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def build_query
|
|
18
|
+
SoapElement.mail(SoapMailConstants::GET_TAG_REQUEST)
|
|
18
19
|
end
|
|
19
20
|
end
|
|
20
21
|
end
|
data/lib/zm/client/task/task.rb
CHANGED
|
@@ -7,12 +7,13 @@ module Zm
|
|
|
7
7
|
include BelongsToFolder
|
|
8
8
|
include BelongsToTag
|
|
9
9
|
|
|
10
|
-
attr_accessor :uid, :priority, :ptst, :percentComplete, :name, :loc, :alarm, :isOrg,
|
|
11
|
-
:
|
|
10
|
+
attr_accessor :uid, :priority, :ptst, :percentComplete, :name, :loc, :alarm, :isOrg,
|
|
11
|
+
:id, :invId, :compNum, :l, :status, :class, :allDay, :f, :tn, :t, :rev,
|
|
12
|
+
:s, :d, :md, :ms, :cm, :sf
|
|
12
13
|
|
|
13
|
-
def download(dest_file_path, fmt
|
|
14
|
-
uploader =
|
|
15
|
-
uploader.download_file(
|
|
14
|
+
def download(dest_file_path, fmt: 'ics')
|
|
15
|
+
uploader = @parent.build_uploader
|
|
16
|
+
uploader.download_file(dest_file_path, id, FolderView::APPOINTMENT, fmt:)
|
|
16
17
|
end
|
|
17
18
|
|
|
18
19
|
def create!
|
|
@@ -6,36 +6,37 @@ module Zm
|
|
|
6
6
|
class TaskJsnsInitializer
|
|
7
7
|
class << self
|
|
8
8
|
def create(parent, json)
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
Task.new(parent).tap do |item|
|
|
10
|
+
update(item, json)
|
|
11
|
+
end
|
|
11
12
|
end
|
|
12
13
|
|
|
13
14
|
def update(item, json)
|
|
14
|
-
item.uid = json
|
|
15
|
-
item.priority = json
|
|
16
|
-
item.ptst = json
|
|
17
|
-
item.percentComplete = json
|
|
18
|
-
item.name = json
|
|
19
|
-
item.loc = json
|
|
20
|
-
item.alarm = json
|
|
21
|
-
item.isOrg = json
|
|
22
|
-
item.id = json
|
|
23
|
-
item.invId = json
|
|
24
|
-
item.compNum = json
|
|
25
|
-
item.l = json
|
|
26
|
-
item.status = json
|
|
27
|
-
item.class = json
|
|
28
|
-
item.allDay = json
|
|
29
|
-
item.f = json
|
|
30
|
-
item.tn = json
|
|
31
|
-
item.t = json
|
|
32
|
-
item.rev = json
|
|
33
|
-
item.s = json
|
|
34
|
-
item.d = json
|
|
35
|
-
item.md = json
|
|
36
|
-
item.ms = json
|
|
37
|
-
item.cm = json
|
|
38
|
-
item.sf = json
|
|
15
|
+
item.uid = json.delete(:uid)
|
|
16
|
+
item.priority = json.delete(:priority)
|
|
17
|
+
item.ptst = json.delete(:ptst)
|
|
18
|
+
item.percentComplete = json.delete(:percentComplete)
|
|
19
|
+
item.name = json.delete(:name)
|
|
20
|
+
item.loc = json.delete(:loc)
|
|
21
|
+
item.alarm = json.delete(:alarm)
|
|
22
|
+
item.isOrg = json.delete(:isOrg)
|
|
23
|
+
item.id = json.delete(:id).to_i
|
|
24
|
+
item.invId = json.delete(:invId)
|
|
25
|
+
item.compNum = json.delete(:compNum)
|
|
26
|
+
item.l = json.delete(:l).to_i
|
|
27
|
+
item.status = json.delete(:status)
|
|
28
|
+
item.class = json.delete(:class)
|
|
29
|
+
item.allDay = json.delete(:allDay)
|
|
30
|
+
item.f = json.delete(:f)
|
|
31
|
+
item.tn = json.delete(:tn)
|
|
32
|
+
item.t = json.delete(:t)
|
|
33
|
+
item.rev = json.delete(:rev)
|
|
34
|
+
item.s = json.delete(:s)
|
|
35
|
+
item.d = json.delete(:d)
|
|
36
|
+
item.md = json.delete(:md)
|
|
37
|
+
item.ms = json.delete(:ms)
|
|
38
|
+
item.cm = json.delete(:cm)
|
|
39
|
+
item.sf = json.delete(:sf)
|
|
39
40
|
|
|
40
41
|
item
|
|
41
42
|
end
|
|
@@ -7,7 +7,7 @@ module Zm
|
|
|
7
7
|
DEFAULT_QUERY = 'in:tasks'
|
|
8
8
|
|
|
9
9
|
def initialize(parent)
|
|
10
|
-
super
|
|
10
|
+
super
|
|
11
11
|
@child_class = Task
|
|
12
12
|
@builder_class = TasksBuilder
|
|
13
13
|
@type = 'task'
|
|
@@ -15,7 +15,7 @@ module Zm
|
|
|
15
15
|
end
|
|
16
16
|
|
|
17
17
|
def find_each(offset: 0, limit: 500, &block)
|
|
18
|
-
(
|
|
18
|
+
(Time.at(0).year..(Time.now.year + 10)).each do |year|
|
|
19
19
|
@start_at = Time.new(year, 1, 1)
|
|
20
20
|
@end_at = Time.new(year, 12, 31)
|
|
21
21
|
@more = true
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Zm
|
|
4
|
+
module Client
|
|
5
|
+
class Token
|
|
6
|
+
def initialize(str)
|
|
7
|
+
@str = str
|
|
8
|
+
@key_id, @hmac, @encoded = @str.split('_')
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
def to_s
|
|
12
|
+
@str
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def decoded
|
|
16
|
+
return @decoded if defined? @decoded
|
|
17
|
+
|
|
18
|
+
@decoded = [@encoded].pack('H*')
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
def metadatas
|
|
22
|
+
return @metadatas if defined? @metadatas
|
|
23
|
+
|
|
24
|
+
@metadatas = decoded.split(';').to_h { |part| part.split(/=\d+:/) }.freeze
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def zimbra_id
|
|
28
|
+
metadatas['id']
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def admin?
|
|
32
|
+
return @admin if defined? @admin
|
|
33
|
+
|
|
34
|
+
@admin = metadatas['admin'] == '1'
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def server_version
|
|
38
|
+
metadatas['version']
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def expire_at
|
|
42
|
+
return @expire_at if defined? @expire_at
|
|
43
|
+
|
|
44
|
+
@expire_at = Time.at(metadatas['exp'].to_f / 1000).freeze
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
def expired?
|
|
48
|
+
expire_at < Time.now
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
end
|
|
@@ -2,152 +2,158 @@
|
|
|
2
2
|
|
|
3
3
|
module Zm
|
|
4
4
|
module Client
|
|
5
|
-
# class for upload
|
|
5
|
+
# class for upload mailbox file
|
|
6
6
|
class Upload
|
|
7
7
|
FMT_TYPES_H = {
|
|
8
|
-
'ics' =>
|
|
9
|
-
'vcard' =>
|
|
8
|
+
'ics' => FolderView::APPOINTMENT,
|
|
9
|
+
'vcard' => FolderView::CONTACT,
|
|
10
|
+
'eml' => FolderView::MESSAGE,
|
|
11
|
+
'vcf' => FolderView::CONTACT
|
|
10
12
|
}.freeze
|
|
11
13
|
|
|
12
|
-
|
|
13
|
-
@parent = parent
|
|
14
|
-
@rac = rac || @parent.rac
|
|
15
|
-
@rac.cookies("ZM_AUTH_TOKEN=#{@parent.token}")
|
|
16
|
-
end
|
|
14
|
+
AUTHORIZED_FOLDER_FMT = %w[zip tgz ics csv tar xml json rss atom html ifb].freeze
|
|
17
15
|
|
|
18
|
-
|
|
19
|
-
raise ZmError, 'home_url is not defined' if @parent.home_url.nil?
|
|
16
|
+
AUTHORIZED_PARAMS = %i[charset auth fmt id list types emptyname disp resolve query meta csvfmt].freeze
|
|
20
17
|
|
|
21
|
-
|
|
22
|
-
@rac.download(url, dest_file_path)
|
|
23
|
-
end
|
|
18
|
+
AUTHORIZED_RESOLVE = %w[replace modify reset skip].freeze
|
|
24
19
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
20
|
+
attr_reader :rest_connector
|
|
21
|
+
attr_accessor :charset, :auth, :emptyname, :disp
|
|
22
|
+
|
|
23
|
+
def initialize(base_url, token, is_token_admin: false, **rest_options)
|
|
24
|
+
raise ZmError, 'base_url must to be present' if base_url.nil?
|
|
28
25
|
|
|
29
|
-
|
|
30
|
-
@
|
|
26
|
+
@charset = 'UTF-8'
|
|
27
|
+
@auth = 'co'
|
|
28
|
+
@emptyname = 'Empty'
|
|
29
|
+
@disp = 'a'
|
|
30
|
+
|
|
31
|
+
yield(self) if block_given?
|
|
32
|
+
|
|
33
|
+
@base_url = base_url
|
|
34
|
+
|
|
35
|
+
@rest_connector = RestConnector.new(**rest_options) do |conn|
|
|
36
|
+
conn.cookies = if is_token_admin
|
|
37
|
+
"ZM_ADMIN_AUTH_TOKEN=#{token}"
|
|
38
|
+
else
|
|
39
|
+
"ZM_AUTH_TOKEN=#{token}"
|
|
40
|
+
end
|
|
41
|
+
end
|
|
31
42
|
end
|
|
32
43
|
|
|
33
|
-
def
|
|
34
|
-
|
|
44
|
+
def download_file(dest_file_path, file_id, type, fmt: nil)
|
|
45
|
+
fmt ||= File.extname(dest_file_path)[1..]
|
|
46
|
+
type ||= FMT_TYPES_H[fmt]
|
|
47
|
+
|
|
48
|
+
raise RestError, 'Invalid fmt type' if type.nil? && fmt.nil?
|
|
49
|
+
|
|
50
|
+
remote_url = download_file_url(fmt, type, file_id)
|
|
51
|
+
@rest_connector.download(remote_url, dest_file_path)
|
|
35
52
|
end
|
|
36
53
|
|
|
37
|
-
def
|
|
38
|
-
|
|
54
|
+
def read_file(file_id, type, fmt: nil)
|
|
55
|
+
type ||= FMT_TYPES_H[fmt]
|
|
39
56
|
|
|
40
|
-
|
|
57
|
+
raise RestError, 'Invalid fmt type' if type.nil? && fmt.nil?
|
|
41
58
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}
|
|
59
|
+
remote_url = download_file_url(fmt, type, file_id)
|
|
60
|
+
@rest_connector.read(remote_url)
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
def download_files(dest_file_path, file_ids, type, fmt: nil)
|
|
64
|
+
fmt ||= File.extname(dest_file_path)[1..]
|
|
65
|
+
type ||= FMT_TYPES_H[fmt]
|
|
50
66
|
|
|
51
|
-
|
|
67
|
+
raise RestError, 'Invalid fmt type' if type.nil? && fmt.nil?
|
|
52
68
|
|
|
53
|
-
|
|
69
|
+
remote_url = download_files_url(fmt, type, file_ids)
|
|
70
|
+
@rest_connector.download(remote_url, dest_file_path)
|
|
54
71
|
end
|
|
55
72
|
|
|
56
|
-
def
|
|
57
|
-
|
|
73
|
+
def download_folder(dest_file_path, folder_id, fmt: nil)
|
|
74
|
+
fmt ||= File.extname(dest_file_path)[1..]
|
|
58
75
|
|
|
59
|
-
|
|
76
|
+
raise RestError, 'Unauthorized fmt parameter' unless AUTHORIZED_FOLDER_FMT.include?(fmt)
|
|
60
77
|
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
emptyname: 'Empty',
|
|
65
|
-
charset: 'UTF-8',
|
|
66
|
-
auth: 'co',
|
|
67
|
-
disp: 'a'
|
|
68
|
-
}
|
|
78
|
+
remote_url = download_folder_url(folder_id, fmt)
|
|
79
|
+
@rest_connector.download(remote_url, dest_file_path)
|
|
80
|
+
end
|
|
69
81
|
|
|
70
|
-
|
|
82
|
+
def send_file(src_file_path, folder_id, fmt: nil, type: nil, resolve: nil)
|
|
83
|
+
fmt ||= File.extname(src_file_path)[1..]
|
|
84
|
+
type ||= FMT_TYPES_H[fmt]
|
|
85
|
+
resolve ||= AUTHORIZED_RESOLVE.first
|
|
71
86
|
|
|
72
|
-
|
|
87
|
+
raise RestError, 'Unauthorized resolve parameter' unless AUTHORIZED_RESOLVE.include?(resolve)
|
|
73
88
|
|
|
74
|
-
|
|
89
|
+
raise RestError, 'Invalid fmt type' if type.nil? && fmt.nil?
|
|
75
90
|
|
|
76
|
-
|
|
91
|
+
remote_url = send_file_url(folder_id, fmt:, type:, resolve:)
|
|
92
|
+
@rest_connector.upload(remote_url, src_file_path)
|
|
77
93
|
end
|
|
78
94
|
|
|
79
|
-
def
|
|
80
|
-
@
|
|
95
|
+
def upload_attachment(src_file_path)
|
|
96
|
+
@rest_connector.upload(upload_attachment_url, src_file_path)
|
|
81
97
|
end
|
|
82
98
|
|
|
83
|
-
def
|
|
84
|
-
|
|
99
|
+
def build_params(**params)
|
|
100
|
+
params.select! { |k, _| AUTHORIZED_PARAMS.include?(k) }
|
|
85
101
|
|
|
86
|
-
|
|
87
|
-
|
|
102
|
+
params[:charset] ||= @charset
|
|
103
|
+
params[:auth] ||= @auth
|
|
104
|
+
params[:emptyname] ||= @emptyname
|
|
105
|
+
params[:disp] ||= @disp
|
|
88
106
|
|
|
89
|
-
|
|
90
|
-
fmt: fmt,
|
|
91
|
-
types: query_value_types(types, fmt),
|
|
92
|
-
resolve: resolve,
|
|
93
|
-
auth: 'co'
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
h.reject! { |_, v| is_blank?(v) }
|
|
107
|
+
params.compact!
|
|
97
108
|
|
|
98
|
-
|
|
109
|
+
params
|
|
110
|
+
end
|
|
99
111
|
|
|
100
|
-
|
|
112
|
+
def format_url_params(params)
|
|
113
|
+
params.map { |k, v| "#{k}=#{v}" }.join('&')
|
|
101
114
|
end
|
|
102
115
|
|
|
103
|
-
def
|
|
104
|
-
|
|
105
|
-
|
|
116
|
+
def format_url(url, str_params)
|
|
117
|
+
return url if str_params.nil? || str_params.empty?
|
|
118
|
+
|
|
119
|
+
"#{url}?#{str_params}"
|
|
106
120
|
end
|
|
107
121
|
|
|
108
|
-
def
|
|
109
|
-
|
|
122
|
+
def download_file_with_url(url, dest_file_path)
|
|
123
|
+
url = File.join(@base_url, url) unless url.start_with?('http')
|
|
124
|
+
@rest_connector.download(url, dest_file_path)
|
|
110
125
|
end
|
|
111
126
|
|
|
112
|
-
def
|
|
113
|
-
h =
|
|
114
|
-
fmt: 'extended,raw'
|
|
115
|
-
}
|
|
127
|
+
def download_folder_url(folder_id, fmt)
|
|
128
|
+
h = build_params(fmt:, id: folder_id)
|
|
116
129
|
|
|
117
|
-
|
|
130
|
+
format_url(@base_url, format_url_params(h))
|
|
118
131
|
end
|
|
119
132
|
|
|
120
|
-
def
|
|
121
|
-
|
|
122
|
-
return { id: ids } unless ids.is_a?(Array)
|
|
123
|
-
return { id: ids.first } if ids.length == 1
|
|
133
|
+
def download_file_url(fmt, type, id)
|
|
134
|
+
h = build_params(fmt:, types: type, id:)
|
|
124
135
|
|
|
125
|
-
|
|
136
|
+
format_url(@base_url, format_url_params(h))
|
|
126
137
|
end
|
|
127
138
|
|
|
128
|
-
def
|
|
129
|
-
|
|
139
|
+
def download_files_url(fmt, type, ids)
|
|
140
|
+
h = build_params(fmt:, types: type, list: ids.join(','))
|
|
130
141
|
|
|
131
|
-
|
|
132
|
-
types.join(',')
|
|
142
|
+
format_url(@base_url, format_url_params(h))
|
|
133
143
|
end
|
|
134
144
|
|
|
135
|
-
def
|
|
136
|
-
|
|
145
|
+
def send_file_url(folder_id, fmt:, type:, resolve:)
|
|
146
|
+
h = build_params(fmt:, types: type, resolve:, id: folder_id)
|
|
137
147
|
|
|
138
|
-
|
|
148
|
+
format_url(@base_url, format_url_params(h))
|
|
139
149
|
end
|
|
140
|
-
end
|
|
141
150
|
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
@str_h = JSON.parse(str[str.index('['), str.length], symbolize_names: true).first
|
|
147
|
-
end
|
|
151
|
+
def upload_attachment_url
|
|
152
|
+
h = {
|
|
153
|
+
fmt: 'extended,raw'
|
|
154
|
+
}
|
|
148
155
|
|
|
149
|
-
|
|
150
|
-
@str_h[:aid]
|
|
156
|
+
File.join(@base_url, 'service/upload') << '?' << format_url_params(h)
|
|
151
157
|
end
|
|
152
158
|
end
|
|
153
159
|
end
|