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,328 @@
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 CustomerProfilesContext < InstanceContext
14
+ class CustomerProfilesEvaluationsList < ListResource
15
+ ##
16
+ # Initialize the CustomerProfilesEvaluationsList
17
+ # @param [Version] version Version that contains the resource
18
+ # @param [String] customer_profile_sid The unique string that we created to
19
+ # identify the customer_profile resource.
20
+ # @return [CustomerProfilesEvaluationsList] CustomerProfilesEvaluationsList
21
+ def initialize(version, customer_profile_sid: nil)
22
+ super(version)
23
+
24
+ # Path Solution
25
+ @solution = {customer_profile_sid: customer_profile_sid}
26
+ @uri = "/CustomerProfiles/#{@solution[:customer_profile_sid]}/Evaluations"
27
+ end
28
+
29
+ ##
30
+ # Create the CustomerProfilesEvaluationsInstance
31
+ # @param [String] policy_sid The unique string of a policy that is associated to
32
+ # the customer_profile resource.
33
+ # @return [CustomerProfilesEvaluationsInstance] Created CustomerProfilesEvaluationsInstance
34
+ def create(policy_sid: nil)
35
+ data = Twilio::Values.of({'PolicySid' => policy_sid, })
36
+
37
+ payload = @version.create('POST', @uri, data: data)
38
+
39
+ CustomerProfilesEvaluationsInstance.new(
40
+ @version,
41
+ payload,
42
+ customer_profile_sid: @solution[:customer_profile_sid],
43
+ )
44
+ end
45
+
46
+ ##
47
+ # Lists CustomerProfilesEvaluationsInstance records from the API as a list.
48
+ # Unlike stream(), this operation is eager and will load `limit` records into
49
+ # memory before returning.
50
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
51
+ # guarantees to never return more than limit. Default is no limit
52
+ # @param [Integer] page_size Number of records to fetch per request, when
53
+ # not set will use the default value of 50 records. If no page_size is defined
54
+ # but a limit is defined, stream() will attempt to read the limit with the most
55
+ # efficient page size, i.e. min(limit, 1000)
56
+ # @return [Array] Array of up to limit results
57
+ def list(limit: nil, page_size: nil)
58
+ self.stream(limit: limit, page_size: page_size).entries
59
+ end
60
+
61
+ ##
62
+ # Streams CustomerProfilesEvaluationsInstance records from the API as an Enumerable.
63
+ # This operation lazily loads records as efficiently as possible until the limit
64
+ # is reached.
65
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
66
+ # guarantees to never return more than limit. Default is no limit.
67
+ # @param [Integer] page_size Number of records to fetch per request, when
68
+ # not set will use the default value of 50 records. If no page_size is defined
69
+ # but a limit is defined, stream() will attempt to read the limit with the most
70
+ # efficient page size, i.e. min(limit, 1000)
71
+ # @return [Enumerable] Enumerable that will yield up to limit results
72
+ def stream(limit: nil, page_size: nil)
73
+ limits = @version.read_limits(limit, page_size)
74
+
75
+ page = self.page(page_size: limits[:page_size], )
76
+
77
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
78
+ end
79
+
80
+ ##
81
+ # When passed a block, yields CustomerProfilesEvaluationsInstance records from the API.
82
+ # This operation lazily loads records as efficiently as possible until the limit
83
+ # is reached.
84
+ def each
85
+ limits = @version.read_limits
86
+
87
+ page = self.page(page_size: limits[:page_size], )
88
+
89
+ @version.stream(page,
90
+ limit: limits[:limit],
91
+ page_limit: limits[:page_limit]).each {|x| yield x}
92
+ end
93
+
94
+ ##
95
+ # Retrieve a single page of CustomerProfilesEvaluationsInstance records from the API.
96
+ # Request is executed immediately.
97
+ # @param [String] page_token PageToken provided by the API
98
+ # @param [Integer] page_number Page Number, this value is simply for client state
99
+ # @param [Integer] page_size Number of records to return, defaults to 50
100
+ # @return [Page] Page of CustomerProfilesEvaluationsInstance
101
+ def page(page_token: :unset, page_number: :unset, page_size: :unset)
102
+ params = Twilio::Values.of({
103
+ 'PageToken' => page_token,
104
+ 'Page' => page_number,
105
+ 'PageSize' => page_size,
106
+ })
107
+
108
+ response = @version.page('GET', @uri, params: params)
109
+
110
+ CustomerProfilesEvaluationsPage.new(@version, response, @solution)
111
+ end
112
+
113
+ ##
114
+ # Retrieve a single page of CustomerProfilesEvaluationsInstance records from the API.
115
+ # Request is executed immediately.
116
+ # @param [String] target_url API-generated URL for the requested results page
117
+ # @return [Page] Page of CustomerProfilesEvaluationsInstance
118
+ def get_page(target_url)
119
+ response = @version.domain.request(
120
+ 'GET',
121
+ target_url
122
+ )
123
+ CustomerProfilesEvaluationsPage.new(@version, response, @solution)
124
+ end
125
+
126
+ ##
127
+ # Provide a user friendly representation
128
+ def to_s
129
+ '#<Twilio.Trusthub.V1.CustomerProfilesEvaluationsList>'
130
+ end
131
+ end
132
+
133
+ class CustomerProfilesEvaluationsPage < Page
134
+ ##
135
+ # Initialize the CustomerProfilesEvaluationsPage
136
+ # @param [Version] version Version that contains the resource
137
+ # @param [Response] response Response from the API
138
+ # @param [Hash] solution Path solution for the resource
139
+ # @return [CustomerProfilesEvaluationsPage] CustomerProfilesEvaluationsPage
140
+ def initialize(version, response, solution)
141
+ super(version, response)
142
+
143
+ # Path Solution
144
+ @solution = solution
145
+ end
146
+
147
+ ##
148
+ # Build an instance of CustomerProfilesEvaluationsInstance
149
+ # @param [Hash] payload Payload response from the API
150
+ # @return [CustomerProfilesEvaluationsInstance] CustomerProfilesEvaluationsInstance
151
+ def get_instance(payload)
152
+ CustomerProfilesEvaluationsInstance.new(
153
+ @version,
154
+ payload,
155
+ customer_profile_sid: @solution[:customer_profile_sid],
156
+ )
157
+ end
158
+
159
+ ##
160
+ # Provide a user friendly representation
161
+ def to_s
162
+ '<Twilio.Trusthub.V1.CustomerProfilesEvaluationsPage>'
163
+ end
164
+ end
165
+
166
+ class CustomerProfilesEvaluationsContext < InstanceContext
167
+ ##
168
+ # Initialize the CustomerProfilesEvaluationsContext
169
+ # @param [Version] version Version that contains the resource
170
+ # @param [String] customer_profile_sid The unique string that we created to
171
+ # identify the customer_profile resource.
172
+ # @param [String] sid The unique string that identifies the Evaluation resource.
173
+ # @return [CustomerProfilesEvaluationsContext] CustomerProfilesEvaluationsContext
174
+ def initialize(version, customer_profile_sid, sid)
175
+ super(version)
176
+
177
+ # Path Solution
178
+ @solution = {customer_profile_sid: customer_profile_sid, sid: sid, }
179
+ @uri = "/CustomerProfiles/#{@solution[:customer_profile_sid]}/Evaluations/#{@solution[:sid]}"
180
+ end
181
+
182
+ ##
183
+ # Fetch the CustomerProfilesEvaluationsInstance
184
+ # @return [CustomerProfilesEvaluationsInstance] Fetched CustomerProfilesEvaluationsInstance
185
+ def fetch
186
+ payload = @version.fetch('GET', @uri)
187
+
188
+ CustomerProfilesEvaluationsInstance.new(
189
+ @version,
190
+ payload,
191
+ customer_profile_sid: @solution[:customer_profile_sid],
192
+ sid: @solution[:sid],
193
+ )
194
+ end
195
+
196
+ ##
197
+ # Provide a user friendly representation
198
+ def to_s
199
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
200
+ "#<Twilio.Trusthub.V1.CustomerProfilesEvaluationsContext #{context}>"
201
+ end
202
+
203
+ ##
204
+ # Provide a detailed, user friendly representation
205
+ def inspect
206
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
207
+ "#<Twilio.Trusthub.V1.CustomerProfilesEvaluationsContext #{context}>"
208
+ end
209
+ end
210
+
211
+ class CustomerProfilesEvaluationsInstance < InstanceResource
212
+ ##
213
+ # Initialize the CustomerProfilesEvaluationsInstance
214
+ # @param [Version] version Version that contains the resource
215
+ # @param [Hash] payload payload that contains response from Twilio
216
+ # @param [String] customer_profile_sid The unique string that we created to
217
+ # identify the customer_profile resource.
218
+ # @param [String] sid The unique string that identifies the Evaluation resource.
219
+ # @return [CustomerProfilesEvaluationsInstance] CustomerProfilesEvaluationsInstance
220
+ def initialize(version, payload, customer_profile_sid: nil, sid: nil)
221
+ super(version)
222
+
223
+ # Marshaled Properties
224
+ @properties = {
225
+ 'sid' => payload['sid'],
226
+ 'account_sid' => payload['account_sid'],
227
+ 'policy_sid' => payload['policy_sid'],
228
+ 'customer_profile_sid' => payload['customer_profile_sid'],
229
+ 'status' => payload['status'],
230
+ 'results' => payload['results'],
231
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
232
+ 'url' => payload['url'],
233
+ }
234
+
235
+ # Context
236
+ @instance_context = nil
237
+ @params = {'customer_profile_sid' => customer_profile_sid, 'sid' => sid || @properties['sid'], }
238
+ end
239
+
240
+ ##
241
+ # Generate an instance context for the instance, the context is capable of
242
+ # performing various actions. All instance actions are proxied to the context
243
+ # @return [CustomerProfilesEvaluationsContext] CustomerProfilesEvaluationsContext for this CustomerProfilesEvaluationsInstance
244
+ def context
245
+ unless @instance_context
246
+ @instance_context = CustomerProfilesEvaluationsContext.new(
247
+ @version,
248
+ @params['customer_profile_sid'],
249
+ @params['sid'],
250
+ )
251
+ end
252
+ @instance_context
253
+ end
254
+
255
+ ##
256
+ # @return [String] The unique string that identifies the Evaluation resource
257
+ def sid
258
+ @properties['sid']
259
+ end
260
+
261
+ ##
262
+ # @return [String] The SID of the Account that created the resource
263
+ def account_sid
264
+ @properties['account_sid']
265
+ end
266
+
267
+ ##
268
+ # @return [String] The unique string of a policy
269
+ def policy_sid
270
+ @properties['policy_sid']
271
+ end
272
+
273
+ ##
274
+ # @return [String] The unique string that identifies the resource
275
+ def customer_profile_sid
276
+ @properties['customer_profile_sid']
277
+ end
278
+
279
+ ##
280
+ # @return [customer_profiles_evaluations.Status] The compliance status of the Evaluation resource
281
+ def status
282
+ @properties['status']
283
+ end
284
+
285
+ ##
286
+ # @return [Array[Hash]] The results of the Evaluation resource
287
+ def results
288
+ @properties['results']
289
+ end
290
+
291
+ ##
292
+ # @return [Time] The date_created
293
+ def date_created
294
+ @properties['date_created']
295
+ end
296
+
297
+ ##
298
+ # @return [String] The url
299
+ def url
300
+ @properties['url']
301
+ end
302
+
303
+ ##
304
+ # Fetch the CustomerProfilesEvaluationsInstance
305
+ # @return [CustomerProfilesEvaluationsInstance] Fetched CustomerProfilesEvaluationsInstance
306
+ def fetch
307
+ context.fetch
308
+ end
309
+
310
+ ##
311
+ # Provide a user friendly representation
312
+ def to_s
313
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
314
+ "<Twilio.Trusthub.V1.CustomerProfilesEvaluationsInstance #{values}>"
315
+ end
316
+
317
+ ##
318
+ # Provide a detailed, user friendly representation
319
+ def inspect
320
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
321
+ "<Twilio.Trusthub.V1.CustomerProfilesEvaluationsInstance #{values}>"
322
+ end
323
+ end
324
+ end
325
+ end
326
+ end
327
+ end
328
+ end
@@ -0,0 +1,356 @@
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 EndUserList < ListResource
14
+ ##
15
+ # Initialize the EndUserList
16
+ # @param [Version] version Version that contains the resource
17
+ # @return [EndUserList] EndUserList
18
+ def initialize(version)
19
+ super(version)
20
+
21
+ # Path Solution
22
+ @solution = {}
23
+ @uri = "/EndUsers"
24
+ end
25
+
26
+ ##
27
+ # Create the EndUserInstance
28
+ # @param [String] friendly_name The string that you assigned to describe the
29
+ # resource.
30
+ # @param [String] type The type of end user of the Bundle resource - can be
31
+ # `individual` or `business`.
32
+ # @param [Hash] attributes The set of parameters that are the attributes of the
33
+ # End User resource which are derived End User Types.
34
+ # @return [EndUserInstance] Created EndUserInstance
35
+ def create(friendly_name: nil, type: nil, attributes: :unset)
36
+ data = Twilio::Values.of({
37
+ 'FriendlyName' => friendly_name,
38
+ 'Type' => type,
39
+ 'Attributes' => Twilio.serialize_object(attributes),
40
+ })
41
+
42
+ payload = @version.create('POST', @uri, data: data)
43
+
44
+ EndUserInstance.new(@version, payload, )
45
+ end
46
+
47
+ ##
48
+ # Lists EndUserInstance records from the API as a list.
49
+ # Unlike stream(), this operation is eager and will load `limit` records into
50
+ # memory before returning.
51
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
52
+ # guarantees to never return more than limit. Default is no limit
53
+ # @param [Integer] page_size Number of records to fetch per request, when
54
+ # not set will use the default value of 50 records. If no page_size is defined
55
+ # but a limit is defined, stream() will attempt to read the limit with the most
56
+ # efficient page size, i.e. min(limit, 1000)
57
+ # @return [Array] Array of up to limit results
58
+ def list(limit: nil, page_size: nil)
59
+ self.stream(limit: limit, page_size: page_size).entries
60
+ end
61
+
62
+ ##
63
+ # Streams EndUserInstance records from the API as an Enumerable.
64
+ # This operation lazily loads records as efficiently as possible until the limit
65
+ # is reached.
66
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
67
+ # guarantees to never return more than limit. Default is no limit.
68
+ # @param [Integer] page_size Number of records to fetch per request, when
69
+ # not set will use the default value of 50 records. If no page_size is defined
70
+ # but a limit is defined, stream() will attempt to read the limit with the most
71
+ # efficient page size, i.e. min(limit, 1000)
72
+ # @return [Enumerable] Enumerable that will yield up to limit results
73
+ def stream(limit: nil, page_size: nil)
74
+ limits = @version.read_limits(limit, page_size)
75
+
76
+ page = self.page(page_size: limits[:page_size], )
77
+
78
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
79
+ end
80
+
81
+ ##
82
+ # When passed a block, yields EndUserInstance records from the API.
83
+ # This operation lazily loads records as efficiently as possible until the limit
84
+ # is reached.
85
+ def each
86
+ limits = @version.read_limits
87
+
88
+ page = self.page(page_size: limits[:page_size], )
89
+
90
+ @version.stream(page,
91
+ limit: limits[:limit],
92
+ page_limit: limits[:page_limit]).each {|x| yield x}
93
+ end
94
+
95
+ ##
96
+ # Retrieve a single page of EndUserInstance records from the API.
97
+ # Request is executed immediately.
98
+ # @param [String] page_token PageToken provided by the API
99
+ # @param [Integer] page_number Page Number, this value is simply for client state
100
+ # @param [Integer] page_size Number of records to return, defaults to 50
101
+ # @return [Page] Page of EndUserInstance
102
+ def page(page_token: :unset, page_number: :unset, page_size: :unset)
103
+ params = Twilio::Values.of({
104
+ 'PageToken' => page_token,
105
+ 'Page' => page_number,
106
+ 'PageSize' => page_size,
107
+ })
108
+
109
+ response = @version.page('GET', @uri, params: params)
110
+
111
+ EndUserPage.new(@version, response, @solution)
112
+ end
113
+
114
+ ##
115
+ # Retrieve a single page of EndUserInstance records from the API.
116
+ # Request is executed immediately.
117
+ # @param [String] target_url API-generated URL for the requested results page
118
+ # @return [Page] Page of EndUserInstance
119
+ def get_page(target_url)
120
+ response = @version.domain.request(
121
+ 'GET',
122
+ target_url
123
+ )
124
+ EndUserPage.new(@version, response, @solution)
125
+ end
126
+
127
+ ##
128
+ # Provide a user friendly representation
129
+ def to_s
130
+ '#<Twilio.Trusthub.V1.EndUserList>'
131
+ end
132
+ end
133
+
134
+ class EndUserPage < Page
135
+ ##
136
+ # Initialize the EndUserPage
137
+ # @param [Version] version Version that contains the resource
138
+ # @param [Response] response Response from the API
139
+ # @param [Hash] solution Path solution for the resource
140
+ # @return [EndUserPage] EndUserPage
141
+ def initialize(version, response, solution)
142
+ super(version, response)
143
+
144
+ # Path Solution
145
+ @solution = solution
146
+ end
147
+
148
+ ##
149
+ # Build an instance of EndUserInstance
150
+ # @param [Hash] payload Payload response from the API
151
+ # @return [EndUserInstance] EndUserInstance
152
+ def get_instance(payload)
153
+ EndUserInstance.new(@version, payload, )
154
+ end
155
+
156
+ ##
157
+ # Provide a user friendly representation
158
+ def to_s
159
+ '<Twilio.Trusthub.V1.EndUserPage>'
160
+ end
161
+ end
162
+
163
+ class EndUserContext < InstanceContext
164
+ ##
165
+ # Initialize the EndUserContext
166
+ # @param [Version] version Version that contains the resource
167
+ # @param [String] sid The unique string created by Twilio to identify the End User
168
+ # resource.
169
+ # @return [EndUserContext] EndUserContext
170
+ def initialize(version, sid)
171
+ super(version)
172
+
173
+ # Path Solution
174
+ @solution = {sid: sid, }
175
+ @uri = "/EndUsers/#{@solution[:sid]}"
176
+ end
177
+
178
+ ##
179
+ # Fetch the EndUserInstance
180
+ # @return [EndUserInstance] Fetched EndUserInstance
181
+ def fetch
182
+ payload = @version.fetch('GET', @uri)
183
+
184
+ EndUserInstance.new(@version, payload, sid: @solution[:sid], )
185
+ end
186
+
187
+ ##
188
+ # Update the EndUserInstance
189
+ # @param [String] friendly_name The string that you assigned to describe the
190
+ # resource.
191
+ # @param [Hash] attributes The set of parameters that are the attributes of the
192
+ # End User resource which are derived End User Types.
193
+ # @return [EndUserInstance] Updated EndUserInstance
194
+ def update(friendly_name: :unset, attributes: :unset)
195
+ data = Twilio::Values.of({
196
+ 'FriendlyName' => friendly_name,
197
+ 'Attributes' => Twilio.serialize_object(attributes),
198
+ })
199
+
200
+ payload = @version.update('POST', @uri, data: data)
201
+
202
+ EndUserInstance.new(@version, payload, sid: @solution[:sid], )
203
+ end
204
+
205
+ ##
206
+ # Delete the EndUserInstance
207
+ # @return [Boolean] true if delete succeeds, false otherwise
208
+ def delete
209
+ @version.delete('DELETE', @uri)
210
+ end
211
+
212
+ ##
213
+ # Provide a user friendly representation
214
+ def to_s
215
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
216
+ "#<Twilio.Trusthub.V1.EndUserContext #{context}>"
217
+ end
218
+
219
+ ##
220
+ # Provide a detailed, user friendly representation
221
+ def inspect
222
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
223
+ "#<Twilio.Trusthub.V1.EndUserContext #{context}>"
224
+ end
225
+ end
226
+
227
+ class EndUserInstance < InstanceResource
228
+ ##
229
+ # Initialize the EndUserInstance
230
+ # @param [Version] version Version that contains the resource
231
+ # @param [Hash] payload payload that contains response from Twilio
232
+ # @param [String] sid The unique string created by Twilio to identify the End User
233
+ # resource.
234
+ # @return [EndUserInstance] EndUserInstance
235
+ def initialize(version, payload, sid: nil)
236
+ super(version)
237
+
238
+ # Marshaled Properties
239
+ @properties = {
240
+ 'sid' => payload['sid'],
241
+ 'account_sid' => payload['account_sid'],
242
+ 'friendly_name' => payload['friendly_name'],
243
+ 'type' => payload['type'],
244
+ 'attributes' => payload['attributes'],
245
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
246
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
247
+ 'url' => payload['url'],
248
+ }
249
+
250
+ # Context
251
+ @instance_context = nil
252
+ @params = {'sid' => sid || @properties['sid'], }
253
+ end
254
+
255
+ ##
256
+ # Generate an instance context for the instance, the context is capable of
257
+ # performing various actions. All instance actions are proxied to the context
258
+ # @return [EndUserContext] EndUserContext for this EndUserInstance
259
+ def context
260
+ unless @instance_context
261
+ @instance_context = EndUserContext.new(@version, @params['sid'], )
262
+ end
263
+ @instance_context
264
+ end
265
+
266
+ ##
267
+ # @return [String] The unique string that identifies the resource
268
+ def sid
269
+ @properties['sid']
270
+ end
271
+
272
+ ##
273
+ # @return [String] The SID of the Account that created the resource
274
+ def account_sid
275
+ @properties['account_sid']
276
+ end
277
+
278
+ ##
279
+ # @return [String] The string that you assigned to describe the resource
280
+ def friendly_name
281
+ @properties['friendly_name']
282
+ end
283
+
284
+ ##
285
+ # @return [String] The type of end user of the Bundle resource
286
+ def type
287
+ @properties['type']
288
+ end
289
+
290
+ ##
291
+ # @return [Hash] The set of parameters that compose the End Users resource
292
+ def attributes
293
+ @properties['attributes']
294
+ end
295
+
296
+ ##
297
+ # @return [Time] The ISO 8601 date and time in GMT when the resource was created
298
+ def date_created
299
+ @properties['date_created']
300
+ end
301
+
302
+ ##
303
+ # @return [Time] The ISO 8601 date and time in GMT when the resource was last updated
304
+ def date_updated
305
+ @properties['date_updated']
306
+ end
307
+
308
+ ##
309
+ # @return [String] The absolute URL of the End User resource
310
+ def url
311
+ @properties['url']
312
+ end
313
+
314
+ ##
315
+ # Fetch the EndUserInstance
316
+ # @return [EndUserInstance] Fetched EndUserInstance
317
+ def fetch
318
+ context.fetch
319
+ end
320
+
321
+ ##
322
+ # Update the EndUserInstance
323
+ # @param [String] friendly_name The string that you assigned to describe the
324
+ # resource.
325
+ # @param [Hash] attributes The set of parameters that are the attributes of the
326
+ # End User resource which are derived End User Types.
327
+ # @return [EndUserInstance] Updated EndUserInstance
328
+ def update(friendly_name: :unset, attributes: :unset)
329
+ context.update(friendly_name: friendly_name, attributes: attributes, )
330
+ end
331
+
332
+ ##
333
+ # Delete the EndUserInstance
334
+ # @return [Boolean] true if delete succeeds, false otherwise
335
+ def delete
336
+ context.delete
337
+ end
338
+
339
+ ##
340
+ # Provide a user friendly representation
341
+ def to_s
342
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
343
+ "<Twilio.Trusthub.V1.EndUserInstance #{values}>"
344
+ end
345
+
346
+ ##
347
+ # Provide a detailed, user friendly representation
348
+ def inspect
349
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
350
+ "<Twilio.Trusthub.V1.EndUserInstance #{values}>"
351
+ end
352
+ end
353
+ end
354
+ end
355
+ end
356
+ end