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
|
@@ -6,28 +6,29 @@ module Zm
|
|
|
6
6
|
class SearchFolderJsnsInitializer
|
|
7
7
|
class << self
|
|
8
8
|
def create(parent, json)
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
SearchFolder.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
|
|
15
|
+
item.id = json.delete(:id)
|
|
16
|
+
item.name = json.delete(:name)
|
|
16
17
|
|
|
17
|
-
item.uuid = json
|
|
18
|
-
item.deletable = json
|
|
19
|
-
item.absFolderPath = json
|
|
20
|
-
item.l = json
|
|
21
|
-
item.luuid = json
|
|
22
|
-
item.color = json
|
|
23
|
-
item.rgb = json
|
|
24
|
-
item.rev = json
|
|
25
|
-
item.ms = json
|
|
26
|
-
item.webOfflineSyncDays = json
|
|
27
|
-
item.activesyncdisabled = json
|
|
28
|
-
item.query = json
|
|
29
|
-
item.sortBy = json
|
|
30
|
-
item.types = json
|
|
18
|
+
item.uuid = json.delete(:uuid)
|
|
19
|
+
item.deletable = json.delete(:deletable)
|
|
20
|
+
item.absFolderPath = json.delete(:absFolderPath)
|
|
21
|
+
item.l = json.delete(:l)
|
|
22
|
+
item.luuid = json.delete(:luuid)
|
|
23
|
+
item.color = json.delete(:color)
|
|
24
|
+
item.rgb = json.delete(:rgb)
|
|
25
|
+
item.rev = json.delete(:rev)
|
|
26
|
+
item.ms = json.delete(:ms)
|
|
27
|
+
item.webOfflineSyncDays = json.delete(:webOfflineSyncDays)
|
|
28
|
+
item.activesyncdisabled = json.delete(:activesyncdisabled)
|
|
29
|
+
item.query = json.delete(:query)
|
|
30
|
+
item.sortBy = json.delete(:sortBy)
|
|
31
|
+
item.types = json.delete(:types)
|
|
31
32
|
|
|
32
33
|
item
|
|
33
34
|
end
|
|
@@ -7,14 +7,15 @@ module Zm
|
|
|
7
7
|
def initialize(parent)
|
|
8
8
|
@child_class = SearchFolder
|
|
9
9
|
@builder_class = SearchFoldersBuilder
|
|
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_SEARCH_FOLDER_REQUEST)
|
|
18
19
|
end
|
|
19
20
|
end
|
|
20
21
|
end
|
|
@@ -10,15 +10,21 @@ module Zm
|
|
|
10
10
|
include HasSoapAdminConnector
|
|
11
11
|
|
|
12
12
|
def mta_queues
|
|
13
|
-
@mta_queues
|
|
13
|
+
return @mta_queues if defined? @mta_queues
|
|
14
|
+
|
|
15
|
+
@mta_queues = MtaQueuesCollection.new(self)
|
|
14
16
|
end
|
|
15
17
|
|
|
16
18
|
def backups
|
|
17
|
-
@backups
|
|
19
|
+
return @backups if defined? @backups
|
|
20
|
+
|
|
21
|
+
@backups = BackupsCollection.new(self)
|
|
18
22
|
end
|
|
19
23
|
|
|
20
24
|
def accounts
|
|
21
|
-
@accounts
|
|
25
|
+
return @accounts if defined? @accounts
|
|
26
|
+
|
|
27
|
+
@accounts = ServerAccountsCollection.new(self)
|
|
22
28
|
end
|
|
23
29
|
|
|
24
30
|
def update!(hash)
|
|
@@ -6,13 +6,15 @@ module Zm
|
|
|
6
6
|
class ServerAccountsCollection < AccountsCollection
|
|
7
7
|
def initialize(parent)
|
|
8
8
|
@target_server_id = parent.id
|
|
9
|
-
super
|
|
9
|
+
super
|
|
10
10
|
end
|
|
11
11
|
|
|
12
12
|
private
|
|
13
13
|
|
|
14
14
|
def ldap_filter
|
|
15
|
-
@ldap_filter
|
|
15
|
+
return @ldap_filter if defined? @ldap_filter
|
|
16
|
+
|
|
17
|
+
@ldap_filter = LdapFilter.new("(zimbraMailHost=#{@parent.name})")
|
|
16
18
|
end
|
|
17
19
|
end
|
|
18
20
|
end
|
|
@@ -9,31 +9,39 @@ module Zm
|
|
|
9
9
|
@child_class = Server
|
|
10
10
|
@builder_class = ServersBuilder
|
|
11
11
|
@service = nil
|
|
12
|
-
super
|
|
12
|
+
super
|
|
13
13
|
end
|
|
14
14
|
|
|
15
15
|
def find_by!(hash)
|
|
16
|
-
|
|
17
|
-
node_server = SoapElement.create(SoapConstants::SERVER).add_attribute(SoapConstants::BY, hash.keys.first).add_content(hash.values.first)
|
|
18
|
-
soap_request.add_node(node_server)
|
|
19
|
-
soap_request.add_attribute(SoapConstants::ATTRS, attrs_comma) unless @attrs.nil?
|
|
20
|
-
entry = sac.invoke(soap_request)[:GetServerResponse][:server].first
|
|
16
|
+
entry = sac.invoke(build_find_by(hash))[:GetServerResponse][:server].first
|
|
21
17
|
|
|
22
18
|
reset_query_params
|
|
23
19
|
ServerJsnsInitializer.create(@parent, entry)
|
|
24
20
|
end
|
|
25
21
|
|
|
22
|
+
def build_find_by(hash)
|
|
23
|
+
soap_request = SoapElement.admin(SoapAdminConstants::GET_SERVER_REQUEST)
|
|
24
|
+
node_server = SoapElement.create(SoapConstants::SERVER)
|
|
25
|
+
.add_attribute(SoapConstants::BY, hash.keys.first)
|
|
26
|
+
.add_content(hash.values.first)
|
|
27
|
+
soap_request.add_node(node_server)
|
|
28
|
+
soap_request.add_attribute(SoapConstants::ATTRS, attrs_comma) unless @attrs.nil?
|
|
29
|
+
soap_request
|
|
30
|
+
end
|
|
31
|
+
|
|
26
32
|
def where(service)
|
|
27
33
|
@service = service
|
|
28
34
|
self
|
|
29
35
|
end
|
|
30
36
|
|
|
31
|
-
private
|
|
32
|
-
|
|
33
37
|
def make_query
|
|
38
|
+
sac.invoke(build_query)
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def build_query
|
|
34
42
|
soap_request = SoapElement.admin(SoapAdminConstants::GET_ALL_SERVERS_REQUEST)
|
|
35
43
|
soap_request.add_attribute(SoapConstants::SERVICE, @service) unless @service.nil?
|
|
36
|
-
|
|
44
|
+
soap_request
|
|
37
45
|
end
|
|
38
46
|
end
|
|
39
47
|
end
|
|
@@ -4,11 +4,13 @@ module Zm
|
|
|
4
4
|
module Client
|
|
5
5
|
# class for account share
|
|
6
6
|
class Share < Base::Object
|
|
7
|
-
attr_accessor :ownerId, :ownerEmail, :ownerName, :folderId, :folderUuid, :folderPath,
|
|
8
|
-
:granteeType, :granteeId, :granteeName, :mid
|
|
7
|
+
attr_accessor :ownerId, :ownerEmail, :ownerName, :folderId, :folderUuid, :folderPath,
|
|
8
|
+
:view, :rights, :granteeType, :granteeId, :granteeName, :mid
|
|
9
9
|
|
|
10
10
|
def mountpoints
|
|
11
|
-
@mountpoints
|
|
11
|
+
return @mountpoints if defined? @mountpoints
|
|
12
|
+
|
|
13
|
+
@mountpoints = ShareMountPointsCollection.new(self)
|
|
12
14
|
end
|
|
13
15
|
end
|
|
14
16
|
end
|
|
@@ -6,23 +6,24 @@ module Zm
|
|
|
6
6
|
class ShareJsnsInitializer
|
|
7
7
|
class << self
|
|
8
8
|
def create(parent, json)
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
Share.new(parent).tap do |item|
|
|
10
|
+
update(item, json)
|
|
11
|
+
end
|
|
11
12
|
end
|
|
12
13
|
|
|
13
14
|
def update(item, json)
|
|
14
|
-
item.ownerId = json
|
|
15
|
-
item.ownerEmail = json
|
|
16
|
-
item.ownerName = json
|
|
17
|
-
item.folderId = json
|
|
18
|
-
item.folderUuid = json
|
|
19
|
-
item.folderPath = json
|
|
20
|
-
item.view = json
|
|
21
|
-
item.rights = json
|
|
22
|
-
item.granteeType = json
|
|
23
|
-
item.granteeId = json
|
|
24
|
-
item.granteeName = json
|
|
25
|
-
item.mid = json
|
|
15
|
+
item.ownerId = json.delete(:ownerId)
|
|
16
|
+
item.ownerEmail = json.delete(:ownerEmail)
|
|
17
|
+
item.ownerName = json.delete(:ownerName)
|
|
18
|
+
item.folderId = json.delete(:folderId)
|
|
19
|
+
item.folderUuid = json.delete(:folderUuid)
|
|
20
|
+
item.folderPath = json.delete(:folderPath)
|
|
21
|
+
item.view = json.delete(:view)
|
|
22
|
+
item.rights = json.delete(:rights)
|
|
23
|
+
item.granteeType = json.delete(:granteeType)
|
|
24
|
+
item.granteeId = json.delete(:granteeId)
|
|
25
|
+
item.granteeName = json.delete(:granteeName)
|
|
26
|
+
item.mid = json.delete(:mid)
|
|
26
27
|
|
|
27
28
|
item
|
|
28
29
|
end
|
|
@@ -10,7 +10,7 @@ module Zm
|
|
|
10
10
|
|
|
11
11
|
def new
|
|
12
12
|
MountPoint.new(@share.parent) do |mp|
|
|
13
|
-
mp.l = FolderDefault::ROOT
|
|
13
|
+
mp.l = FolderDefault::ROOT.id
|
|
14
14
|
mp.name = default_mountpoint_name
|
|
15
15
|
mp.zid = @share.ownerId
|
|
16
16
|
mp.rid = @share.folderId
|
|
@@ -19,12 +19,9 @@ module Zm
|
|
|
19
19
|
end
|
|
20
20
|
|
|
21
21
|
def all
|
|
22
|
-
@all
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
def all!
|
|
26
|
-
@all = @share.parent.mountpoints.all.select { |mp| mp.zid == @share.ownerId && mp.rid == @share.folderId }
|
|
22
|
+
@share.parent.mountpoints.all.select { |mp| mp.zid == @share.ownerId && mp.rid == @share.folderId }
|
|
27
23
|
end
|
|
24
|
+
alias all! all
|
|
28
25
|
|
|
29
26
|
private
|
|
30
27
|
|
|
@@ -21,14 +21,17 @@ module Zm
|
|
|
21
21
|
end
|
|
22
22
|
|
|
23
23
|
def share_response
|
|
24
|
-
soap_request = SoapElement.account(SoapAccountConstants::GET_SHARE_INFO_REQUEST)
|
|
24
|
+
soap_request = SoapElement.account(SoapAccountConstants::GET_SHARE_INFO_REQUEST)
|
|
25
|
+
.add_attributes({ includeSelf: SoapUtils::OFF })
|
|
25
26
|
|
|
26
27
|
unless @owner_name.nil?
|
|
27
|
-
node_owner = SoapElement.create('owner')
|
|
28
|
+
node_owner = SoapElement.create('owner')
|
|
29
|
+
.add_attributes({ by: :name })
|
|
30
|
+
.add_content(@owner_name)
|
|
28
31
|
soap_request.add_node(node_owner)
|
|
29
32
|
end
|
|
30
33
|
|
|
31
|
-
@parent.
|
|
34
|
+
@parent.soap_connector.invoke(soap_request)
|
|
32
35
|
end
|
|
33
36
|
|
|
34
37
|
def share_builder
|
|
@@ -4,36 +4,19 @@ module Zm
|
|
|
4
4
|
module Client
|
|
5
5
|
# class account signature
|
|
6
6
|
class Signature < Base::Object
|
|
7
|
+
include RequestMethodsMailbox
|
|
8
|
+
|
|
7
9
|
attr_accessor :id, :name, :txt, :html
|
|
8
10
|
|
|
9
11
|
def create!
|
|
10
|
-
rep = @parent.
|
|
12
|
+
rep = @parent.soap_connector.invoke(build_create)
|
|
11
13
|
@id = rep[:CreateSignatureResponse][:signature].first[:id]
|
|
12
14
|
end
|
|
13
15
|
|
|
14
|
-
def modify!
|
|
15
|
-
@parent.sacc.invoke(jsns_builder.to_update)
|
|
16
|
-
true
|
|
17
|
-
end
|
|
18
|
-
|
|
19
16
|
def update!(*args)
|
|
20
17
|
raise NotImplementedError
|
|
21
18
|
end
|
|
22
19
|
|
|
23
|
-
def rename!(new_name)
|
|
24
|
-
return if new_name == @name
|
|
25
|
-
|
|
26
|
-
@parent.sacc.invoke(jsns_builder.to_rename(new_name))
|
|
27
|
-
@name = new_name
|
|
28
|
-
end
|
|
29
|
-
|
|
30
|
-
def delete!
|
|
31
|
-
return false if @id.nil?
|
|
32
|
-
|
|
33
|
-
@parent.sacc.invoke(jsns_builder.to_delete)
|
|
34
|
-
@id = nil
|
|
35
|
-
end
|
|
36
|
-
|
|
37
20
|
def type
|
|
38
21
|
return ContentType::HTML unless html.nil?
|
|
39
22
|
|
|
@@ -55,7 +38,9 @@ module Zm
|
|
|
55
38
|
private
|
|
56
39
|
|
|
57
40
|
def jsns_builder
|
|
58
|
-
@jsns_builder
|
|
41
|
+
return @jsns_builder if defined? @jsns_builder
|
|
42
|
+
|
|
43
|
+
@jsns_builder = SignatureJsnsBuilder.new(self)
|
|
59
44
|
end
|
|
60
45
|
end
|
|
61
46
|
end
|
|
@@ -10,20 +10,24 @@ module Zm
|
|
|
10
10
|
|
|
11
11
|
def to_jsns
|
|
12
12
|
soap_request = SoapElement.account(SoapAccountConstants::CREATE_SIGNATURE_REQUEST)
|
|
13
|
-
node_signature = SoapElement.create(SoapConstants::SIGNATURE)
|
|
13
|
+
node_signature = SoapElement.create(SoapConstants::SIGNATURE)
|
|
14
|
+
.add_attributes({ name: @signature.name })
|
|
14
15
|
soap_request.add_node(node_signature)
|
|
15
|
-
node_content = SoapElement.create(SoapConstants::CONTENT)
|
|
16
|
-
|
|
16
|
+
node_content = SoapElement.create(SoapConstants::CONTENT)
|
|
17
|
+
.add_attribute(SoapConstants::TYPE, @signature.type)
|
|
18
|
+
.add_content(@signature.content)
|
|
17
19
|
node_signature.add_node(node_content)
|
|
18
20
|
soap_request
|
|
19
21
|
end
|
|
20
22
|
|
|
21
23
|
def to_update
|
|
22
24
|
soap_request = SoapElement.account(SoapAccountConstants::MODIFY_SIGNATURE_REQUEST)
|
|
23
|
-
node_signature = SoapElement.create(SoapConstants::SIGNATURE)
|
|
25
|
+
node_signature = SoapElement.create(SoapConstants::SIGNATURE)
|
|
26
|
+
.add_attributes({ name: @signature.name, id: @signature.id })
|
|
24
27
|
soap_request.add_node(node_signature)
|
|
25
|
-
node_content = SoapElement.create(SoapConstants::CONTENT)
|
|
26
|
-
|
|
28
|
+
node_content = SoapElement.create(SoapConstants::CONTENT)
|
|
29
|
+
.add_attribute(SoapConstants::TYPE, @signature.type)
|
|
30
|
+
.add_content(@signature.content)
|
|
27
31
|
node_signature.add_node(node_content)
|
|
28
32
|
soap_request
|
|
29
33
|
end
|
|
@@ -42,7 +46,8 @@ module Zm
|
|
|
42
46
|
|
|
43
47
|
def to_delete
|
|
44
48
|
soap_request = SoapElement.account(SoapAccountConstants::DELETE_SIGNATURE_REQUEST)
|
|
45
|
-
node_signature = SoapElement.create(SoapConstants::SIGNATURE)
|
|
49
|
+
node_signature = SoapElement.create(SoapConstants::SIGNATURE)
|
|
50
|
+
.add_attribute(SoapConstants::ID, @signature.id)
|
|
46
51
|
soap_request.add_node(node_signature)
|
|
47
52
|
soap_request
|
|
48
53
|
end
|
|
@@ -6,13 +6,14 @@ module Zm
|
|
|
6
6
|
class SignatureJsnsInitializer
|
|
7
7
|
class << self
|
|
8
8
|
def create(parent, json)
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
Signature.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
|
|
15
|
+
item.id = json.delete(:id)
|
|
16
|
+
item.name = json.delete(:name)
|
|
16
17
|
|
|
17
18
|
content = json[:content].is_a?(Array) ? json[:content] : [json[:content]]
|
|
18
19
|
|
|
@@ -7,14 +7,15 @@ module Zm
|
|
|
7
7
|
def initialize(parent)
|
|
8
8
|
@child_class = Signature
|
|
9
9
|
@builder_class = SignaturesBuilder
|
|
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.account(SoapAccountConstants::GET_SIGNATURES_REQUEST)
|
|
18
19
|
end
|
|
19
20
|
end
|
|
20
21
|
end
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Zm
|
|
4
|
+
module Client
|
|
5
|
+
module RequestMethodsAdmin
|
|
6
|
+
def delete!
|
|
7
|
+
sac.invoke(build_delete)
|
|
8
|
+
@id = nil
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
def build_delete
|
|
12
|
+
jsns_builder.to_delete
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def modify!
|
|
16
|
+
sac.invoke(build_modify)
|
|
17
|
+
true
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
def build_modify
|
|
21
|
+
jsns_builder.to_update
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def build_create
|
|
25
|
+
jsns_builder.to_create
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
def update!(hash)
|
|
29
|
+
return false if hash.delete_if { |k, v| v.nil? || !respond_to?(k) }.empty?
|
|
30
|
+
|
|
31
|
+
do_update!(hash)
|
|
32
|
+
|
|
33
|
+
hash.each do |key, value|
|
|
34
|
+
update_attribute(key, value)
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
true
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def rename!(new_name)
|
|
41
|
+
sac.invoke(build_rename(new_name))
|
|
42
|
+
@name = new_name
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
def build_rename(new_name)
|
|
46
|
+
jsns_builder.to_rename(new_name)
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
private
|
|
50
|
+
|
|
51
|
+
def do_update!(hash)
|
|
52
|
+
sac.invoke(jsns_builder.to_patch(hash))
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
end
|
|
56
|
+
end
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Zm
|
|
4
|
+
module Client
|
|
5
|
+
module RequestMethodsMailbox
|
|
6
|
+
def build_create
|
|
7
|
+
jsns_builder.to_jsns
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def modify!
|
|
11
|
+
@parent.soap_connector.invoke(build_modify)
|
|
12
|
+
true
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def build_modify
|
|
16
|
+
jsns_builder.to_update
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
def update!(hash)
|
|
20
|
+
return false if hash.delete_if { |k, v| v.nil? || !respond_to?(k) }.empty?
|
|
21
|
+
|
|
22
|
+
do_update!(hash)
|
|
23
|
+
|
|
24
|
+
hash.each do |key, value|
|
|
25
|
+
update_attribute(key, value)
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
true
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def rename!(new_name)
|
|
32
|
+
return false if new_name == @name
|
|
33
|
+
|
|
34
|
+
@parent.soap_connector.invoke(build_rename(new_name))
|
|
35
|
+
@name = new_name
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
def build_rename(new_name)
|
|
39
|
+
jsns_builder.to_rename(new_name)
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
def delete!
|
|
43
|
+
return false if id.nil?
|
|
44
|
+
|
|
45
|
+
@parent.soap_connector.invoke(build_delete)
|
|
46
|
+
# remove_instance_variable(:id)
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
def build_delete
|
|
50
|
+
jsns_builder.to_delete
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
private
|
|
54
|
+
|
|
55
|
+
def do_update!(hash)
|
|
56
|
+
@parent.soap_connector.invoke(jsns_builder.to_patch(hash))
|
|
57
|
+
end
|
|
58
|
+
end
|
|
59
|
+
end
|
|
60
|
+
end
|
|
@@ -6,6 +6,7 @@ module Zm
|
|
|
6
6
|
BY = 'by'
|
|
7
7
|
ID = 'id'
|
|
8
8
|
NAME = 'name'
|
|
9
|
+
EXPIRES = 'expires'
|
|
9
10
|
A = 'a'
|
|
10
11
|
N = 'n'
|
|
11
12
|
TRUE = 'TRUE'
|
|
@@ -20,6 +21,7 @@ module Zm
|
|
|
20
21
|
SERVER = 'server'
|
|
21
22
|
COS = 'cos'
|
|
22
23
|
DL = 'dl'
|
|
24
|
+
DLM = 'dlm'
|
|
23
25
|
DOMAIN = 'domain'
|
|
24
26
|
CAL_RESOURCE = 'calresource'
|
|
25
27
|
|
|
@@ -35,6 +37,7 @@ module Zm
|
|
|
35
37
|
CONTENT = 'content'
|
|
36
38
|
|
|
37
39
|
APPOINTMENT = 'appointment'
|
|
40
|
+
CONTACT = 'contact'
|
|
38
41
|
DOCUMENT = 'document'
|
|
39
42
|
MESSAGE = 'message'
|
|
40
43
|
TAG = 'tag'
|
|
@@ -50,6 +53,10 @@ module Zm
|
|
|
50
53
|
SMTP = 'smtp'
|
|
51
54
|
|
|
52
55
|
TEXT_CALENDAR = 'text/calendar'
|
|
56
|
+
CSV = 'csv'
|
|
57
|
+
|
|
58
|
+
NAMESPACE_STR = 'urn:zimbra'
|
|
59
|
+
BATCH_REQUEST = 'BatchRequest'
|
|
53
60
|
end
|
|
54
61
|
end
|
|
55
62
|
end
|
|
@@ -9,6 +9,7 @@ module Zm
|
|
|
9
9
|
@token = nil
|
|
10
10
|
@user_agent = 'zmsoap'
|
|
11
11
|
@target_server = nil
|
|
12
|
+
@account = nil
|
|
12
13
|
end
|
|
13
14
|
|
|
14
15
|
def token(str)
|
|
@@ -26,12 +27,20 @@ module Zm
|
|
|
26
27
|
self
|
|
27
28
|
end
|
|
28
29
|
|
|
30
|
+
def account(by, value)
|
|
31
|
+
@account = { by: by, _content: value }
|
|
32
|
+
self
|
|
33
|
+
end
|
|
34
|
+
|
|
29
35
|
def to_hash
|
|
30
|
-
{
|
|
36
|
+
h = {
|
|
31
37
|
authToken: @token,
|
|
32
38
|
userAgent: { name: @user_agent },
|
|
39
|
+
account: @account,
|
|
33
40
|
targetServer: @target_server
|
|
34
|
-
}
|
|
41
|
+
}
|
|
42
|
+
h.compact!
|
|
43
|
+
h
|
|
35
44
|
end
|
|
36
45
|
end
|
|
37
46
|
end
|
|
@@ -6,3 +6,6 @@ require 'zm/client/soap_request/account_soap_constants'
|
|
|
6
6
|
require 'zm/client/soap_request/mail_soap_constants'
|
|
7
7
|
require 'zm/client/soap_request/soap_constants'
|
|
8
8
|
require 'zm/client/soap_request/soap_element'
|
|
9
|
+
|
|
10
|
+
require 'zm/client/soap_request/request_methods_admin'
|
|
11
|
+
require 'zm/client/soap_request/request_methods_mailbox'
|