twilio-ruby 5.47.0 → 5.48.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (44) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES.md +17 -0
  3. data/README.md +2 -2
  4. data/lib/twilio-ruby/rest/client.rb +7 -0
  5. data/lib/twilio-ruby/rest/events/v1/subscription.rb +2 -2
  6. data/lib/twilio-ruby/rest/messaging.rb +0 -14
  7. data/lib/twilio-ruby/rest/messaging/v1.rb +0 -22
  8. data/lib/twilio-ruby/rest/trusthub.rb +100 -0
  9. data/lib/twilio-ruby/rest/trusthub/v1.rb +139 -0
  10. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles.rb +523 -0
  11. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_channel_endpoint_assignment.rb +359 -0
  12. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_entity_assignments.rb +330 -0
  13. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_evaluations.rb +328 -0
  14. data/lib/twilio-ruby/rest/trusthub/v1/end_user.rb +356 -0
  15. data/lib/twilio-ruby/rest/trusthub/v1/end_user_type.rb +271 -0
  16. data/lib/twilio-ruby/rest/{messaging/v1/use_case.rb → trusthub/v1/policies.rb} +110 -46
  17. data/lib/twilio-ruby/rest/{messaging/v1/campaign.rb → trusthub/v1/supporting_document.rb} +125 -143
  18. data/lib/twilio-ruby/rest/trusthub/v1/supporting_document_type.rb +271 -0
  19. data/lib/twilio-ruby/rest/trusthub/v1/trust_products.rb +523 -0
  20. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_channel_endpoint_assignment.rb +359 -0
  21. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_entity_assignments.rb +330 -0
  22. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_evaluations.rb +328 -0
  23. data/lib/twilio-ruby/rest/verify.rb +9 -0
  24. data/lib/twilio-ruby/rest/verify/v2.rb +15 -0
  25. data/lib/twilio-ruby/rest/verify/v2/verification_attempt.rb +329 -0
  26. data/lib/twilio-ruby/version.rb +1 -1
  27. data/spec/integration/api/v2010/account/incoming_phone_number_spec.rb +4 -16
  28. data/spec/integration/trusthub/v1/customer_profiles/customer_profiles_channel_endpoint_assignment_spec.rb +192 -0
  29. data/spec/integration/trusthub/v1/customer_profiles/customer_profiles_entity_assignments_spec.rb +186 -0
  30. data/spec/integration/trusthub/v1/customer_profiles/customer_profiles_evaluations_spec.rb +615 -0
  31. data/spec/integration/trusthub/v1/customer_profiles_spec.rb +255 -0
  32. data/spec/integration/trusthub/v1/end_user_spec.rb +247 -0
  33. data/spec/integration/trusthub/v1/end_user_type_spec.rb +176 -0
  34. data/spec/integration/trusthub/v1/policies_spec.rb +252 -0
  35. data/spec/integration/trusthub/v1/supporting_document_spec.rb +235 -0
  36. data/spec/integration/trusthub/v1/supporting_document_type_spec.rb +159 -0
  37. data/spec/integration/trusthub/v1/trust_products/trust_products_channel_endpoint_assignment_spec.rb +192 -0
  38. data/spec/integration/trusthub/v1/trust_products/trust_products_entity_assignments_spec.rb +186 -0
  39. data/spec/integration/trusthub/v1/trust_products/trust_products_evaluations_spec.rb +615 -0
  40. data/spec/integration/trusthub/v1/trust_products_spec.rb +255 -0
  41. data/spec/integration/verify/v2/verification_attempt_spec.rb +146 -0
  42. metadata +46 -8
  43. data/spec/integration/messaging/v1/campaign_spec.rb +0 -194
  44. data/spec/integration/messaging/v1/use_case_spec.rb +0 -55
@@ -0,0 +1,271 @@
1
+ ##
2
+ # This code was generated by
3
+ # \ / _ _ _| _ _
4
+ # | (_)\/(_)(_|\/| |(/_ v1.0.0
5
+ # / /
6
+ #
7
+ # frozen_string_literal: true
8
+
9
+ module Twilio
10
+ module REST
11
+ class Trusthub < Domain
12
+ class V1 < Version
13
+ class SupportingDocumentTypeList < ListResource
14
+ ##
15
+ # Initialize the SupportingDocumentTypeList
16
+ # @param [Version] version Version that contains the resource
17
+ # @return [SupportingDocumentTypeList] SupportingDocumentTypeList
18
+ def initialize(version)
19
+ super(version)
20
+
21
+ # Path Solution
22
+ @solution = {}
23
+ @uri = "/SupportingDocumentTypes"
24
+ end
25
+
26
+ ##
27
+ # Lists SupportingDocumentTypeInstance records from the API as a list.
28
+ # Unlike stream(), this operation is eager and will load `limit` records into
29
+ # memory before returning.
30
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
31
+ # guarantees to never return more than limit. Default is no limit
32
+ # @param [Integer] page_size Number of records to fetch per request, when
33
+ # not set will use the default value of 50 records. If no page_size is defined
34
+ # but a limit is defined, stream() will attempt to read the limit with the most
35
+ # efficient page size, i.e. min(limit, 1000)
36
+ # @return [Array] Array of up to limit results
37
+ def list(limit: nil, page_size: nil)
38
+ self.stream(limit: limit, page_size: page_size).entries
39
+ end
40
+
41
+ ##
42
+ # Streams SupportingDocumentTypeInstance records from the API as an Enumerable.
43
+ # This operation lazily loads records as efficiently as possible until the limit
44
+ # is reached.
45
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
46
+ # guarantees to never return more than limit. Default is no limit.
47
+ # @param [Integer] page_size Number of records to fetch per request, when
48
+ # not set will use the default value of 50 records. If no page_size is defined
49
+ # but a limit is defined, stream() will attempt to read the limit with the most
50
+ # efficient page size, i.e. min(limit, 1000)
51
+ # @return [Enumerable] Enumerable that will yield up to limit results
52
+ def stream(limit: nil, page_size: nil)
53
+ limits = @version.read_limits(limit, page_size)
54
+
55
+ page = self.page(page_size: limits[:page_size], )
56
+
57
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
58
+ end
59
+
60
+ ##
61
+ # When passed a block, yields SupportingDocumentTypeInstance records from the API.
62
+ # This operation lazily loads records as efficiently as possible until the limit
63
+ # is reached.
64
+ def each
65
+ limits = @version.read_limits
66
+
67
+ page = self.page(page_size: limits[:page_size], )
68
+
69
+ @version.stream(page,
70
+ limit: limits[:limit],
71
+ page_limit: limits[:page_limit]).each {|x| yield x}
72
+ end
73
+
74
+ ##
75
+ # Retrieve a single page of SupportingDocumentTypeInstance records from the API.
76
+ # Request is executed immediately.
77
+ # @param [String] page_token PageToken provided by the API
78
+ # @param [Integer] page_number Page Number, this value is simply for client state
79
+ # @param [Integer] page_size Number of records to return, defaults to 50
80
+ # @return [Page] Page of SupportingDocumentTypeInstance
81
+ def page(page_token: :unset, page_number: :unset, page_size: :unset)
82
+ params = Twilio::Values.of({
83
+ 'PageToken' => page_token,
84
+ 'Page' => page_number,
85
+ 'PageSize' => page_size,
86
+ })
87
+
88
+ response = @version.page('GET', @uri, params: params)
89
+
90
+ SupportingDocumentTypePage.new(@version, response, @solution)
91
+ end
92
+
93
+ ##
94
+ # Retrieve a single page of SupportingDocumentTypeInstance records from the API.
95
+ # Request is executed immediately.
96
+ # @param [String] target_url API-generated URL for the requested results page
97
+ # @return [Page] Page of SupportingDocumentTypeInstance
98
+ def get_page(target_url)
99
+ response = @version.domain.request(
100
+ 'GET',
101
+ target_url
102
+ )
103
+ SupportingDocumentTypePage.new(@version, response, @solution)
104
+ end
105
+
106
+ ##
107
+ # Provide a user friendly representation
108
+ def to_s
109
+ '#<Twilio.Trusthub.V1.SupportingDocumentTypeList>'
110
+ end
111
+ end
112
+
113
+ class SupportingDocumentTypePage < Page
114
+ ##
115
+ # Initialize the SupportingDocumentTypePage
116
+ # @param [Version] version Version that contains the resource
117
+ # @param [Response] response Response from the API
118
+ # @param [Hash] solution Path solution for the resource
119
+ # @return [SupportingDocumentTypePage] SupportingDocumentTypePage
120
+ def initialize(version, response, solution)
121
+ super(version, response)
122
+
123
+ # Path Solution
124
+ @solution = solution
125
+ end
126
+
127
+ ##
128
+ # Build an instance of SupportingDocumentTypeInstance
129
+ # @param [Hash] payload Payload response from the API
130
+ # @return [SupportingDocumentTypeInstance] SupportingDocumentTypeInstance
131
+ def get_instance(payload)
132
+ SupportingDocumentTypeInstance.new(@version, payload, )
133
+ end
134
+
135
+ ##
136
+ # Provide a user friendly representation
137
+ def to_s
138
+ '<Twilio.Trusthub.V1.SupportingDocumentTypePage>'
139
+ end
140
+ end
141
+
142
+ class SupportingDocumentTypeContext < InstanceContext
143
+ ##
144
+ # Initialize the SupportingDocumentTypeContext
145
+ # @param [Version] version Version that contains the resource
146
+ # @param [String] sid The unique string that identifies the Supporting Document
147
+ # Type resource.
148
+ # @return [SupportingDocumentTypeContext] SupportingDocumentTypeContext
149
+ def initialize(version, sid)
150
+ super(version)
151
+
152
+ # Path Solution
153
+ @solution = {sid: sid, }
154
+ @uri = "/SupportingDocumentTypes/#{@solution[:sid]}"
155
+ end
156
+
157
+ ##
158
+ # Fetch the SupportingDocumentTypeInstance
159
+ # @return [SupportingDocumentTypeInstance] Fetched SupportingDocumentTypeInstance
160
+ def fetch
161
+ payload = @version.fetch('GET', @uri)
162
+
163
+ SupportingDocumentTypeInstance.new(@version, payload, sid: @solution[:sid], )
164
+ end
165
+
166
+ ##
167
+ # Provide a user friendly representation
168
+ def to_s
169
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
170
+ "#<Twilio.Trusthub.V1.SupportingDocumentTypeContext #{context}>"
171
+ end
172
+
173
+ ##
174
+ # Provide a detailed, user friendly representation
175
+ def inspect
176
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
177
+ "#<Twilio.Trusthub.V1.SupportingDocumentTypeContext #{context}>"
178
+ end
179
+ end
180
+
181
+ class SupportingDocumentTypeInstance < InstanceResource
182
+ ##
183
+ # Initialize the SupportingDocumentTypeInstance
184
+ # @param [Version] version Version that contains the resource
185
+ # @param [Hash] payload payload that contains response from Twilio
186
+ # @param [String] sid The unique string that identifies the Supporting Document
187
+ # Type resource.
188
+ # @return [SupportingDocumentTypeInstance] SupportingDocumentTypeInstance
189
+ def initialize(version, payload, sid: nil)
190
+ super(version)
191
+
192
+ # Marshaled Properties
193
+ @properties = {
194
+ 'sid' => payload['sid'],
195
+ 'friendly_name' => payload['friendly_name'],
196
+ 'machine_name' => payload['machine_name'],
197
+ 'fields' => payload['fields'],
198
+ 'url' => payload['url'],
199
+ }
200
+
201
+ # Context
202
+ @instance_context = nil
203
+ @params = {'sid' => sid || @properties['sid'], }
204
+ end
205
+
206
+ ##
207
+ # Generate an instance context for the instance, the context is capable of
208
+ # performing various actions. All instance actions are proxied to the context
209
+ # @return [SupportingDocumentTypeContext] SupportingDocumentTypeContext for this SupportingDocumentTypeInstance
210
+ def context
211
+ unless @instance_context
212
+ @instance_context = SupportingDocumentTypeContext.new(@version, @params['sid'], )
213
+ end
214
+ @instance_context
215
+ end
216
+
217
+ ##
218
+ # @return [String] The unique string that identifies the Supporting Document Type resource
219
+ def sid
220
+ @properties['sid']
221
+ end
222
+
223
+ ##
224
+ # @return [String] A human-readable description of the Supporting Document Type resource
225
+ def friendly_name
226
+ @properties['friendly_name']
227
+ end
228
+
229
+ ##
230
+ # @return [String] The machine-readable description of the Supporting Document Type resource
231
+ def machine_name
232
+ @properties['machine_name']
233
+ end
234
+
235
+ ##
236
+ # @return [Array[Hash]] The required information for creating a Supporting Document
237
+ def fields
238
+ @properties['fields']
239
+ end
240
+
241
+ ##
242
+ # @return [String] The absolute URL of the Supporting Document Type resource
243
+ def url
244
+ @properties['url']
245
+ end
246
+
247
+ ##
248
+ # Fetch the SupportingDocumentTypeInstance
249
+ # @return [SupportingDocumentTypeInstance] Fetched SupportingDocumentTypeInstance
250
+ def fetch
251
+ context.fetch
252
+ end
253
+
254
+ ##
255
+ # Provide a user friendly representation
256
+ def to_s
257
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
258
+ "<Twilio.Trusthub.V1.SupportingDocumentTypeInstance #{values}>"
259
+ end
260
+
261
+ ##
262
+ # Provide a detailed, user friendly representation
263
+ def inspect
264
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
265
+ "<Twilio.Trusthub.V1.SupportingDocumentTypeInstance #{values}>"
266
+ end
267
+ end
268
+ end
269
+ end
270
+ end
271
+ end
@@ -0,0 +1,523 @@
1
+ ##
2
+ # This code was generated by
3
+ # \ / _ _ _| _ _
4
+ # | (_)\/(_)(_|\/| |(/_ v1.0.0
5
+ # / /
6
+ #
7
+ # frozen_string_literal: true
8
+
9
+ module Twilio
10
+ module REST
11
+ class Trusthub < Domain
12
+ class V1 < Version
13
+ class TrustProductsList < ListResource
14
+ ##
15
+ # Initialize the TrustProductsList
16
+ # @param [Version] version Version that contains the resource
17
+ # @return [TrustProductsList] TrustProductsList
18
+ def initialize(version)
19
+ super(version)
20
+
21
+ # Path Solution
22
+ @solution = {}
23
+ @uri = "/TrustProducts"
24
+ end
25
+
26
+ ##
27
+ # Create the TrustProductsInstance
28
+ # @param [String] friendly_name The string that you assigned to describe the
29
+ # resource.
30
+ # @param [String] email The email address that will receive updates when the
31
+ # Customer-Profile resource changes status.
32
+ # @param [String] policy_sid The unique string of a policy that is associated to
33
+ # the Customer-Profile resource.
34
+ # @param [String] status_callback The URL we call to inform your application of
35
+ # status changes.
36
+ # @return [TrustProductsInstance] Created TrustProductsInstance
37
+ def create(friendly_name: nil, email: nil, policy_sid: nil, status_callback: :unset)
38
+ data = Twilio::Values.of({
39
+ 'FriendlyName' => friendly_name,
40
+ 'Email' => email,
41
+ 'PolicySid' => policy_sid,
42
+ 'StatusCallback' => status_callback,
43
+ })
44
+
45
+ payload = @version.create('POST', @uri, data: data)
46
+
47
+ TrustProductsInstance.new(@version, payload, )
48
+ end
49
+
50
+ ##
51
+ # Lists TrustProductsInstance records from the API as a list.
52
+ # Unlike stream(), this operation is eager and will load `limit` records into
53
+ # memory before returning.
54
+ # @param [trust_products.Status] status The verification status of the
55
+ # Customer-Profile resource.
56
+ # @param [String] friendly_name The string that you assigned to describe the
57
+ # resource.
58
+ # @param [String] policy_sid The unique string of a policy that is associated to
59
+ # the Customer-Profile resource.
60
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
61
+ # guarantees to never return more than limit. Default is no limit
62
+ # @param [Integer] page_size Number of records to fetch per request, when
63
+ # not set will use the default value of 50 records. If no page_size is defined
64
+ # but a limit is defined, stream() will attempt to read the limit with the most
65
+ # efficient page size, i.e. min(limit, 1000)
66
+ # @return [Array] Array of up to limit results
67
+ def list(status: :unset, friendly_name: :unset, policy_sid: :unset, limit: nil, page_size: nil)
68
+ self.stream(
69
+ status: status,
70
+ friendly_name: friendly_name,
71
+ policy_sid: policy_sid,
72
+ limit: limit,
73
+ page_size: page_size
74
+ ).entries
75
+ end
76
+
77
+ ##
78
+ # Streams TrustProductsInstance records from the API as an Enumerable.
79
+ # This operation lazily loads records as efficiently as possible until the limit
80
+ # is reached.
81
+ # @param [trust_products.Status] status The verification status of the
82
+ # Customer-Profile resource.
83
+ # @param [String] friendly_name The string that you assigned to describe the
84
+ # resource.
85
+ # @param [String] policy_sid The unique string of a policy that is associated to
86
+ # the Customer-Profile resource.
87
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
88
+ # guarantees to never return more than limit. Default is no limit.
89
+ # @param [Integer] page_size Number of records to fetch per request, when
90
+ # not set will use the default value of 50 records. If no page_size is defined
91
+ # but a limit is defined, stream() will attempt to read the limit with the most
92
+ # efficient page size, i.e. min(limit, 1000)
93
+ # @return [Enumerable] Enumerable that will yield up to limit results
94
+ def stream(status: :unset, friendly_name: :unset, policy_sid: :unset, limit: nil, page_size: nil)
95
+ limits = @version.read_limits(limit, page_size)
96
+
97
+ page = self.page(
98
+ status: status,
99
+ friendly_name: friendly_name,
100
+ policy_sid: policy_sid,
101
+ page_size: limits[:page_size],
102
+ )
103
+
104
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
105
+ end
106
+
107
+ ##
108
+ # When passed a block, yields TrustProductsInstance records from the API.
109
+ # This operation lazily loads records as efficiently as possible until the limit
110
+ # is reached.
111
+ def each
112
+ limits = @version.read_limits
113
+
114
+ page = self.page(page_size: limits[:page_size], )
115
+
116
+ @version.stream(page,
117
+ limit: limits[:limit],
118
+ page_limit: limits[:page_limit]).each {|x| yield x}
119
+ end
120
+
121
+ ##
122
+ # Retrieve a single page of TrustProductsInstance records from the API.
123
+ # Request is executed immediately.
124
+ # @param [trust_products.Status] status The verification status of the
125
+ # Customer-Profile resource.
126
+ # @param [String] friendly_name The string that you assigned to describe the
127
+ # resource.
128
+ # @param [String] policy_sid The unique string of a policy that is associated to
129
+ # the Customer-Profile resource.
130
+ # @param [String] page_token PageToken provided by the API
131
+ # @param [Integer] page_number Page Number, this value is simply for client state
132
+ # @param [Integer] page_size Number of records to return, defaults to 50
133
+ # @return [Page] Page of TrustProductsInstance
134
+ def page(status: :unset, friendly_name: :unset, policy_sid: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
135
+ params = Twilio::Values.of({
136
+ 'Status' => status,
137
+ 'FriendlyName' => friendly_name,
138
+ 'PolicySid' => policy_sid,
139
+ 'PageToken' => page_token,
140
+ 'Page' => page_number,
141
+ 'PageSize' => page_size,
142
+ })
143
+
144
+ response = @version.page('GET', @uri, params: params)
145
+
146
+ TrustProductsPage.new(@version, response, @solution)
147
+ end
148
+
149
+ ##
150
+ # Retrieve a single page of TrustProductsInstance records from the API.
151
+ # Request is executed immediately.
152
+ # @param [String] target_url API-generated URL for the requested results page
153
+ # @return [Page] Page of TrustProductsInstance
154
+ def get_page(target_url)
155
+ response = @version.domain.request(
156
+ 'GET',
157
+ target_url
158
+ )
159
+ TrustProductsPage.new(@version, response, @solution)
160
+ end
161
+
162
+ ##
163
+ # Provide a user friendly representation
164
+ def to_s
165
+ '#<Twilio.Trusthub.V1.TrustProductsList>'
166
+ end
167
+ end
168
+
169
+ class TrustProductsPage < Page
170
+ ##
171
+ # Initialize the TrustProductsPage
172
+ # @param [Version] version Version that contains the resource
173
+ # @param [Response] response Response from the API
174
+ # @param [Hash] solution Path solution for the resource
175
+ # @return [TrustProductsPage] TrustProductsPage
176
+ def initialize(version, response, solution)
177
+ super(version, response)
178
+
179
+ # Path Solution
180
+ @solution = solution
181
+ end
182
+
183
+ ##
184
+ # Build an instance of TrustProductsInstance
185
+ # @param [Hash] payload Payload response from the API
186
+ # @return [TrustProductsInstance] TrustProductsInstance
187
+ def get_instance(payload)
188
+ TrustProductsInstance.new(@version, payload, )
189
+ end
190
+
191
+ ##
192
+ # Provide a user friendly representation
193
+ def to_s
194
+ '<Twilio.Trusthub.V1.TrustProductsPage>'
195
+ end
196
+ end
197
+
198
+ class TrustProductsContext < InstanceContext
199
+ ##
200
+ # Initialize the TrustProductsContext
201
+ # @param [Version] version Version that contains the resource
202
+ # @param [String] sid The unique string that we created to identify the
203
+ # Customer-Profile resource.
204
+ # @return [TrustProductsContext] TrustProductsContext
205
+ def initialize(version, sid)
206
+ super(version)
207
+
208
+ # Path Solution
209
+ @solution = {sid: sid, }
210
+ @uri = "/TrustProducts/#{@solution[:sid]}"
211
+
212
+ # Dependents
213
+ @trust_products_entity_assignments = nil
214
+ @trust_products_evaluations = nil
215
+ @trust_products_channel_endpoint_assignment = nil
216
+ end
217
+
218
+ ##
219
+ # Fetch the TrustProductsInstance
220
+ # @return [TrustProductsInstance] Fetched TrustProductsInstance
221
+ def fetch
222
+ payload = @version.fetch('GET', @uri)
223
+
224
+ TrustProductsInstance.new(@version, payload, sid: @solution[:sid], )
225
+ end
226
+
227
+ ##
228
+ # Update the TrustProductsInstance
229
+ # @param [trust_products.Status] status The verification status of the
230
+ # Customer-Profile resource.
231
+ # @param [String] status_callback The URL we call to inform your application of
232
+ # status changes.
233
+ # @param [String] friendly_name The string that you assigned to describe the
234
+ # resource.
235
+ # @param [String] email The email address that will receive updates when the
236
+ # Customer-Profile resource changes status.
237
+ # @return [TrustProductsInstance] Updated TrustProductsInstance
238
+ def update(status: :unset, status_callback: :unset, friendly_name: :unset, email: :unset)
239
+ data = Twilio::Values.of({
240
+ 'Status' => status,
241
+ 'StatusCallback' => status_callback,
242
+ 'FriendlyName' => friendly_name,
243
+ 'Email' => email,
244
+ })
245
+
246
+ payload = @version.update('POST', @uri, data: data)
247
+
248
+ TrustProductsInstance.new(@version, payload, sid: @solution[:sid], )
249
+ end
250
+
251
+ ##
252
+ # Delete the TrustProductsInstance
253
+ # @return [Boolean] true if delete succeeds, false otherwise
254
+ def delete
255
+ @version.delete('DELETE', @uri)
256
+ end
257
+
258
+ ##
259
+ # Access the trust_products_entity_assignments
260
+ # @return [TrustProductsEntityAssignmentsList]
261
+ # @return [TrustProductsEntityAssignmentsContext] if sid was passed.
262
+ def trust_products_entity_assignments(sid=:unset)
263
+ raise ArgumentError, 'sid cannot be nil' if sid.nil?
264
+
265
+ if sid != :unset
266
+ return TrustProductsEntityAssignmentsContext.new(@version, @solution[:sid], sid, )
267
+ end
268
+
269
+ unless @trust_products_entity_assignments
270
+ @trust_products_entity_assignments = TrustProductsEntityAssignmentsList.new(
271
+ @version,
272
+ trust_product_sid: @solution[:sid],
273
+ )
274
+ end
275
+
276
+ @trust_products_entity_assignments
277
+ end
278
+
279
+ ##
280
+ # Access the trust_products_evaluations
281
+ # @return [TrustProductsEvaluationsList]
282
+ # @return [TrustProductsEvaluationsContext] if sid was passed.
283
+ def trust_products_evaluations(sid=:unset)
284
+ raise ArgumentError, 'sid cannot be nil' if sid.nil?
285
+
286
+ if sid != :unset
287
+ return TrustProductsEvaluationsContext.new(@version, @solution[:sid], sid, )
288
+ end
289
+
290
+ unless @trust_products_evaluations
291
+ @trust_products_evaluations = TrustProductsEvaluationsList.new(
292
+ @version,
293
+ trust_product_sid: @solution[:sid],
294
+ )
295
+ end
296
+
297
+ @trust_products_evaluations
298
+ end
299
+
300
+ ##
301
+ # Access the trust_products_channel_endpoint_assignment
302
+ # @return [TrustProductsChannelEndpointAssignmentList]
303
+ # @return [TrustProductsChannelEndpointAssignmentContext] if sid was passed.
304
+ def trust_products_channel_endpoint_assignment(sid=:unset)
305
+ raise ArgumentError, 'sid cannot be nil' if sid.nil?
306
+
307
+ if sid != :unset
308
+ return TrustProductsChannelEndpointAssignmentContext.new(@version, @solution[:sid], sid, )
309
+ end
310
+
311
+ unless @trust_products_channel_endpoint_assignment
312
+ @trust_products_channel_endpoint_assignment = TrustProductsChannelEndpointAssignmentList.new(
313
+ @version,
314
+ trust_product_sid: @solution[:sid],
315
+ )
316
+ end
317
+
318
+ @trust_products_channel_endpoint_assignment
319
+ end
320
+
321
+ ##
322
+ # Provide a user friendly representation
323
+ def to_s
324
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
325
+ "#<Twilio.Trusthub.V1.TrustProductsContext #{context}>"
326
+ end
327
+
328
+ ##
329
+ # Provide a detailed, user friendly representation
330
+ def inspect
331
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
332
+ "#<Twilio.Trusthub.V1.TrustProductsContext #{context}>"
333
+ end
334
+ end
335
+
336
+ class TrustProductsInstance < InstanceResource
337
+ ##
338
+ # Initialize the TrustProductsInstance
339
+ # @param [Version] version Version that contains the resource
340
+ # @param [Hash] payload payload that contains response from Twilio
341
+ # @param [String] sid The unique string that we created to identify the
342
+ # Customer-Profile resource.
343
+ # @return [TrustProductsInstance] TrustProductsInstance
344
+ def initialize(version, payload, sid: nil)
345
+ super(version)
346
+
347
+ # Marshaled Properties
348
+ @properties = {
349
+ 'sid' => payload['sid'],
350
+ 'account_sid' => payload['account_sid'],
351
+ 'policy_sid' => payload['policy_sid'],
352
+ 'friendly_name' => payload['friendly_name'],
353
+ 'status' => payload['status'],
354
+ 'valid_until' => Twilio.deserialize_iso8601_datetime(payload['valid_until']),
355
+ 'email' => payload['email'],
356
+ 'status_callback' => payload['status_callback'],
357
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
358
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
359
+ 'url' => payload['url'],
360
+ 'links' => payload['links'],
361
+ }
362
+
363
+ # Context
364
+ @instance_context = nil
365
+ @params = {'sid' => sid || @properties['sid'], }
366
+ end
367
+
368
+ ##
369
+ # Generate an instance context for the instance, the context is capable of
370
+ # performing various actions. All instance actions are proxied to the context
371
+ # @return [TrustProductsContext] TrustProductsContext for this TrustProductsInstance
372
+ def context
373
+ unless @instance_context
374
+ @instance_context = TrustProductsContext.new(@version, @params['sid'], )
375
+ end
376
+ @instance_context
377
+ end
378
+
379
+ ##
380
+ # @return [String] The unique string that identifies the resource.
381
+ def sid
382
+ @properties['sid']
383
+ end
384
+
385
+ ##
386
+ # @return [String] The SID of the Account that created the resource
387
+ def account_sid
388
+ @properties['account_sid']
389
+ end
390
+
391
+ ##
392
+ # @return [String] The unique string of a policy.
393
+ def policy_sid
394
+ @properties['policy_sid']
395
+ end
396
+
397
+ ##
398
+ # @return [String] The string that you assigned to describe the resource
399
+ def friendly_name
400
+ @properties['friendly_name']
401
+ end
402
+
403
+ ##
404
+ # @return [trust_products.Status] The verification status of the Customer-Profile resource
405
+ def status
406
+ @properties['status']
407
+ end
408
+
409
+ ##
410
+ # @return [Time] The ISO 8601 date and time in GMT when the resource will be valid until.
411
+ def valid_until
412
+ @properties['valid_until']
413
+ end
414
+
415
+ ##
416
+ # @return [String] The email address
417
+ def email
418
+ @properties['email']
419
+ end
420
+
421
+ ##
422
+ # @return [String] The URL we call to inform your application of status changes.
423
+ def status_callback
424
+ @properties['status_callback']
425
+ end
426
+
427
+ ##
428
+ # @return [Time] The ISO 8601 date and time in GMT when the resource was created
429
+ def date_created
430
+ @properties['date_created']
431
+ end
432
+
433
+ ##
434
+ # @return [Time] The ISO 8601 date and time in GMT when the resource was last updated
435
+ def date_updated
436
+ @properties['date_updated']
437
+ end
438
+
439
+ ##
440
+ # @return [String] The absolute URL of the Customer-Profile resource
441
+ def url
442
+ @properties['url']
443
+ end
444
+
445
+ ##
446
+ # @return [String] The URLs of the Assigned Items of the Customer-Profile resource
447
+ def links
448
+ @properties['links']
449
+ end
450
+
451
+ ##
452
+ # Fetch the TrustProductsInstance
453
+ # @return [TrustProductsInstance] Fetched TrustProductsInstance
454
+ def fetch
455
+ context.fetch
456
+ end
457
+
458
+ ##
459
+ # Update the TrustProductsInstance
460
+ # @param [trust_products.Status] status The verification status of the
461
+ # Customer-Profile resource.
462
+ # @param [String] status_callback The URL we call to inform your application of
463
+ # status changes.
464
+ # @param [String] friendly_name The string that you assigned to describe the
465
+ # resource.
466
+ # @param [String] email The email address that will receive updates when the
467
+ # Customer-Profile resource changes status.
468
+ # @return [TrustProductsInstance] Updated TrustProductsInstance
469
+ def update(status: :unset, status_callback: :unset, friendly_name: :unset, email: :unset)
470
+ context.update(
471
+ status: status,
472
+ status_callback: status_callback,
473
+ friendly_name: friendly_name,
474
+ email: email,
475
+ )
476
+ end
477
+
478
+ ##
479
+ # Delete the TrustProductsInstance
480
+ # @return [Boolean] true if delete succeeds, false otherwise
481
+ def delete
482
+ context.delete
483
+ end
484
+
485
+ ##
486
+ # Access the trust_products_entity_assignments
487
+ # @return [trust_products_entity_assignments] trust_products_entity_assignments
488
+ def trust_products_entity_assignments
489
+ context.trust_products_entity_assignments
490
+ end
491
+
492
+ ##
493
+ # Access the trust_products_evaluations
494
+ # @return [trust_products_evaluations] trust_products_evaluations
495
+ def trust_products_evaluations
496
+ context.trust_products_evaluations
497
+ end
498
+
499
+ ##
500
+ # Access the trust_products_channel_endpoint_assignment
501
+ # @return [trust_products_channel_endpoint_assignment] trust_products_channel_endpoint_assignment
502
+ def trust_products_channel_endpoint_assignment
503
+ context.trust_products_channel_endpoint_assignment
504
+ end
505
+
506
+ ##
507
+ # Provide a user friendly representation
508
+ def to_s
509
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
510
+ "<Twilio.Trusthub.V1.TrustProductsInstance #{values}>"
511
+ end
512
+
513
+ ##
514
+ # Provide a detailed, user friendly representation
515
+ def inspect
516
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
517
+ "<Twilio.Trusthub.V1.TrustProductsInstance #{values}>"
518
+ end
519
+ end
520
+ end
521
+ end
522
+ end
523
+ end