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 TrustProductsContext < InstanceContext
14
+ class TrustProductsEvaluationsList < ListResource
15
+ ##
16
+ # Initialize the TrustProductsEvaluationsList
17
+ # @param [Version] version Version that contains the resource
18
+ # @param [String] trust_product_sid The unique string that we created to identify
19
+ # the trust_product resource.
20
+ # @return [TrustProductsEvaluationsList] TrustProductsEvaluationsList
21
+ def initialize(version, trust_product_sid: nil)
22
+ super(version)
23
+
24
+ # Path Solution
25
+ @solution = {trust_product_sid: trust_product_sid}
26
+ @uri = "/TrustProducts/#{@solution[:trust_product_sid]}/Evaluations"
27
+ end
28
+
29
+ ##
30
+ # Create the TrustProductsEvaluationsInstance
31
+ # @param [String] policy_sid The unique string of a policy that is associated to
32
+ # the customer_profile resource.
33
+ # @return [TrustProductsEvaluationsInstance] Created TrustProductsEvaluationsInstance
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
+ TrustProductsEvaluationsInstance.new(
40
+ @version,
41
+ payload,
42
+ trust_product_sid: @solution[:trust_product_sid],
43
+ )
44
+ end
45
+
46
+ ##
47
+ # Lists TrustProductsEvaluationsInstance 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 TrustProductsEvaluationsInstance 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 TrustProductsEvaluationsInstance 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 TrustProductsEvaluationsInstance 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 TrustProductsEvaluationsInstance
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
+ TrustProductsEvaluationsPage.new(@version, response, @solution)
111
+ end
112
+
113
+ ##
114
+ # Retrieve a single page of TrustProductsEvaluationsInstance 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 TrustProductsEvaluationsInstance
118
+ def get_page(target_url)
119
+ response = @version.domain.request(
120
+ 'GET',
121
+ target_url
122
+ )
123
+ TrustProductsEvaluationsPage.new(@version, response, @solution)
124
+ end
125
+
126
+ ##
127
+ # Provide a user friendly representation
128
+ def to_s
129
+ '#<Twilio.Trusthub.V1.TrustProductsEvaluationsList>'
130
+ end
131
+ end
132
+
133
+ class TrustProductsEvaluationsPage < Page
134
+ ##
135
+ # Initialize the TrustProductsEvaluationsPage
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 [TrustProductsEvaluationsPage] TrustProductsEvaluationsPage
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 TrustProductsEvaluationsInstance
149
+ # @param [Hash] payload Payload response from the API
150
+ # @return [TrustProductsEvaluationsInstance] TrustProductsEvaluationsInstance
151
+ def get_instance(payload)
152
+ TrustProductsEvaluationsInstance.new(
153
+ @version,
154
+ payload,
155
+ trust_product_sid: @solution[:trust_product_sid],
156
+ )
157
+ end
158
+
159
+ ##
160
+ # Provide a user friendly representation
161
+ def to_s
162
+ '<Twilio.Trusthub.V1.TrustProductsEvaluationsPage>'
163
+ end
164
+ end
165
+
166
+ class TrustProductsEvaluationsContext < InstanceContext
167
+ ##
168
+ # Initialize the TrustProductsEvaluationsContext
169
+ # @param [Version] version Version that contains the resource
170
+ # @param [String] trust_product_sid The unique string that we created to identify
171
+ # the trust_product resource.
172
+ # @param [String] sid The unique string that identifies the Evaluation resource.
173
+ # @return [TrustProductsEvaluationsContext] TrustProductsEvaluationsContext
174
+ def initialize(version, trust_product_sid, sid)
175
+ super(version)
176
+
177
+ # Path Solution
178
+ @solution = {trust_product_sid: trust_product_sid, sid: sid, }
179
+ @uri = "/TrustProducts/#{@solution[:trust_product_sid]}/Evaluations/#{@solution[:sid]}"
180
+ end
181
+
182
+ ##
183
+ # Fetch the TrustProductsEvaluationsInstance
184
+ # @return [TrustProductsEvaluationsInstance] Fetched TrustProductsEvaluationsInstance
185
+ def fetch
186
+ payload = @version.fetch('GET', @uri)
187
+
188
+ TrustProductsEvaluationsInstance.new(
189
+ @version,
190
+ payload,
191
+ trust_product_sid: @solution[:trust_product_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.TrustProductsEvaluationsContext #{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.TrustProductsEvaluationsContext #{context}>"
208
+ end
209
+ end
210
+
211
+ class TrustProductsEvaluationsInstance < InstanceResource
212
+ ##
213
+ # Initialize the TrustProductsEvaluationsInstance
214
+ # @param [Version] version Version that contains the resource
215
+ # @param [Hash] payload payload that contains response from Twilio
216
+ # @param [String] trust_product_sid The unique string that we created to identify
217
+ # the trust_product resource.
218
+ # @param [String] sid The unique string that identifies the Evaluation resource.
219
+ # @return [TrustProductsEvaluationsInstance] TrustProductsEvaluationsInstance
220
+ def initialize(version, payload, trust_product_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
+ 'trust_product_sid' => payload['trust_product_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 = {'trust_product_sid' => trust_product_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 [TrustProductsEvaluationsContext] TrustProductsEvaluationsContext for this TrustProductsEvaluationsInstance
244
+ def context
245
+ unless @instance_context
246
+ @instance_context = TrustProductsEvaluationsContext.new(
247
+ @version,
248
+ @params['trust_product_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 trust_product_sid
276
+ @properties['trust_product_sid']
277
+ end
278
+
279
+ ##
280
+ # @return [trust_products_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 TrustProductsEvaluationsInstance
305
+ # @return [TrustProductsEvaluationsInstance] Fetched TrustProductsEvaluationsInstance
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.TrustProductsEvaluationsInstance #{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.TrustProductsEvaluationsInstance #{values}>"
322
+ end
323
+ end
324
+ end
325
+ end
326
+ end
327
+ end
328
+ end
@@ -46,6 +46,15 @@ module Twilio
46
46
  self.v2.services(sid)
47
47
  end
48
48
 
49
+ ##
50
+ # @param [String] sid A 34 character string that uniquely identifies this
51
+ # Verification Attempt.
52
+ # @return [Twilio::REST::Verify::V2::VerificationAttemptInstance] if sid was passed.
53
+ # @return [Twilio::REST::Verify::V2::VerificationAttemptList]
54
+ def verification_attempts(sid=:unset)
55
+ self.v2.verification_attempts(sid)
56
+ end
57
+
49
58
  ##
50
59
  # Provide a user friendly representation
51
60
  def to_s
@@ -17,6 +17,7 @@ module Twilio
17
17
  @version = 'v2'
18
18
  @forms = nil
19
19
  @services = nil
20
+ @verification_attempts = nil
20
21
  end
21
22
 
22
23
  ##
@@ -49,6 +50,20 @@ module Twilio
49
50
  end
50
51
  end
51
52
 
53
+ ##
54
+ # @param [String] sid The unique SID identifier of a Verification Attempt
55
+ # @return [Twilio::REST::Verify::V2::VerificationAttemptContext] if sid was passed.
56
+ # @return [Twilio::REST::Verify::V2::VerificationAttemptList]
57
+ def verification_attempts(sid=:unset)
58
+ if sid.nil?
59
+ raise ArgumentError, 'sid cannot be nil'
60
+ elsif sid == :unset
61
+ @verification_attempts ||= VerificationAttemptList.new self
62
+ else
63
+ VerificationAttemptContext.new(self, sid)
64
+ end
65
+ end
66
+
52
67
  ##
53
68
  # Provide a user friendly representation
54
69
  def to_s
@@ -0,0 +1,329 @@
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 Verify < Domain
12
+ class V2 < Version
13
+ class VerificationAttemptList < ListResource
14
+ ##
15
+ # Initialize the VerificationAttemptList
16
+ # @param [Version] version Version that contains the resource
17
+ # @return [VerificationAttemptList] VerificationAttemptList
18
+ def initialize(version)
19
+ super(version)
20
+
21
+ # Path Solution
22
+ @solution = {}
23
+ @uri = "/Attempts"
24
+ end
25
+
26
+ ##
27
+ # Lists VerificationAttemptInstance 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 [Time] date_created_after Datetime filter used to query Verification
31
+ # Attempts created after this datetime.
32
+ # @param [Time] date_created_before Datetime filter used to query Verification
33
+ # Attempts created before this datetime.
34
+ # @param [String] channel_data_to Destination of a verification. Depending on the
35
+ # type of channel, it could be a phone number in E.164 format or an email address.
36
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
37
+ # guarantees to never return more than limit. Default is no limit
38
+ # @param [Integer] page_size Number of records to fetch per request, when
39
+ # not set will use the default value of 50 records. If no page_size is defined
40
+ # but a limit is defined, stream() will attempt to read the limit with the most
41
+ # efficient page size, i.e. min(limit, 1000)
42
+ # @return [Array] Array of up to limit results
43
+ def list(date_created_after: :unset, date_created_before: :unset, channel_data_to: :unset, limit: nil, page_size: nil)
44
+ self.stream(
45
+ date_created_after: date_created_after,
46
+ date_created_before: date_created_before,
47
+ channel_data_to: channel_data_to,
48
+ limit: limit,
49
+ page_size: page_size
50
+ ).entries
51
+ end
52
+
53
+ ##
54
+ # Streams VerificationAttemptInstance records from the API as an Enumerable.
55
+ # This operation lazily loads records as efficiently as possible until the limit
56
+ # is reached.
57
+ # @param [Time] date_created_after Datetime filter used to query Verification
58
+ # Attempts created after this datetime.
59
+ # @param [Time] date_created_before Datetime filter used to query Verification
60
+ # Attempts created before this datetime.
61
+ # @param [String] channel_data_to Destination of a verification. Depending on the
62
+ # type of channel, it could be a phone number in E.164 format or an email address.
63
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
64
+ # guarantees to never return more than limit. Default is no limit.
65
+ # @param [Integer] page_size Number of records to fetch per request, when
66
+ # not set will use the default value of 50 records. If no page_size is defined
67
+ # but a limit is defined, stream() will attempt to read the limit with the most
68
+ # efficient page size, i.e. min(limit, 1000)
69
+ # @return [Enumerable] Enumerable that will yield up to limit results
70
+ def stream(date_created_after: :unset, date_created_before: :unset, channel_data_to: :unset, limit: nil, page_size: nil)
71
+ limits = @version.read_limits(limit, page_size)
72
+
73
+ page = self.page(
74
+ date_created_after: date_created_after,
75
+ date_created_before: date_created_before,
76
+ channel_data_to: channel_data_to,
77
+ page_size: limits[:page_size],
78
+ )
79
+
80
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
81
+ end
82
+
83
+ ##
84
+ # When passed a block, yields VerificationAttemptInstance records from the API.
85
+ # This operation lazily loads records as efficiently as possible until the limit
86
+ # is reached.
87
+ def each
88
+ limits = @version.read_limits
89
+
90
+ page = self.page(page_size: limits[:page_size], )
91
+
92
+ @version.stream(page,
93
+ limit: limits[:limit],
94
+ page_limit: limits[:page_limit]).each {|x| yield x}
95
+ end
96
+
97
+ ##
98
+ # Retrieve a single page of VerificationAttemptInstance records from the API.
99
+ # Request is executed immediately.
100
+ # @param [Time] date_created_after Datetime filter used to query Verification
101
+ # Attempts created after this datetime.
102
+ # @param [Time] date_created_before Datetime filter used to query Verification
103
+ # Attempts created before this datetime.
104
+ # @param [String] channel_data_to Destination of a verification. Depending on the
105
+ # type of channel, it could be a phone number in E.164 format or an email address.
106
+ # @param [String] page_token PageToken provided by the API
107
+ # @param [Integer] page_number Page Number, this value is simply for client state
108
+ # @param [Integer] page_size Number of records to return, defaults to 50
109
+ # @return [Page] Page of VerificationAttemptInstance
110
+ def page(date_created_after: :unset, date_created_before: :unset, channel_data_to: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
111
+ params = Twilio::Values.of({
112
+ 'DateCreatedAfter' => Twilio.serialize_iso8601_datetime(date_created_after),
113
+ 'DateCreatedBefore' => Twilio.serialize_iso8601_datetime(date_created_before),
114
+ 'ChannelData.To' => channel_data_to,
115
+ 'PageToken' => page_token,
116
+ 'Page' => page_number,
117
+ 'PageSize' => page_size,
118
+ })
119
+
120
+ response = @version.page('GET', @uri, params: params)
121
+
122
+ VerificationAttemptPage.new(@version, response, @solution)
123
+ end
124
+
125
+ ##
126
+ # Retrieve a single page of VerificationAttemptInstance records from the API.
127
+ # Request is executed immediately.
128
+ # @param [String] target_url API-generated URL for the requested results page
129
+ # @return [Page] Page of VerificationAttemptInstance
130
+ def get_page(target_url)
131
+ response = @version.domain.request(
132
+ 'GET',
133
+ target_url
134
+ )
135
+ VerificationAttemptPage.new(@version, response, @solution)
136
+ end
137
+
138
+ ##
139
+ # Provide a user friendly representation
140
+ def to_s
141
+ '#<Twilio.Verify.V2.VerificationAttemptList>'
142
+ end
143
+ end
144
+
145
+ class VerificationAttemptPage < Page
146
+ ##
147
+ # Initialize the VerificationAttemptPage
148
+ # @param [Version] version Version that contains the resource
149
+ # @param [Response] response Response from the API
150
+ # @param [Hash] solution Path solution for the resource
151
+ # @return [VerificationAttemptPage] VerificationAttemptPage
152
+ def initialize(version, response, solution)
153
+ super(version, response)
154
+
155
+ # Path Solution
156
+ @solution = solution
157
+ end
158
+
159
+ ##
160
+ # Build an instance of VerificationAttemptInstance
161
+ # @param [Hash] payload Payload response from the API
162
+ # @return [VerificationAttemptInstance] VerificationAttemptInstance
163
+ def get_instance(payload)
164
+ VerificationAttemptInstance.new(@version, payload, )
165
+ end
166
+
167
+ ##
168
+ # Provide a user friendly representation
169
+ def to_s
170
+ '<Twilio.Verify.V2.VerificationAttemptPage>'
171
+ end
172
+ end
173
+
174
+ class VerificationAttemptContext < InstanceContext
175
+ ##
176
+ # Initialize the VerificationAttemptContext
177
+ # @param [Version] version Version that contains the resource
178
+ # @param [String] sid The unique SID identifier of a Verification Attempt
179
+ # @return [VerificationAttemptContext] VerificationAttemptContext
180
+ def initialize(version, sid)
181
+ super(version)
182
+
183
+ # Path Solution
184
+ @solution = {sid: sid, }
185
+ @uri = "/Attempts/#{@solution[:sid]}"
186
+ end
187
+
188
+ ##
189
+ # Fetch the VerificationAttemptInstance
190
+ # @return [VerificationAttemptInstance] Fetched VerificationAttemptInstance
191
+ def fetch
192
+ payload = @version.fetch('GET', @uri)
193
+
194
+ VerificationAttemptInstance.new(@version, payload, sid: @solution[:sid], )
195
+ end
196
+
197
+ ##
198
+ # Provide a user friendly representation
199
+ def to_s
200
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
201
+ "#<Twilio.Verify.V2.VerificationAttemptContext #{context}>"
202
+ end
203
+
204
+ ##
205
+ # Provide a detailed, user friendly representation
206
+ def inspect
207
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
208
+ "#<Twilio.Verify.V2.VerificationAttemptContext #{context}>"
209
+ end
210
+ end
211
+
212
+ class VerificationAttemptInstance < InstanceResource
213
+ ##
214
+ # Initialize the VerificationAttemptInstance
215
+ # @param [Version] version Version that contains the resource
216
+ # @param [Hash] payload payload that contains response from Twilio
217
+ # @param [String] sid The unique SID identifier of a Verification Attempt
218
+ # @return [VerificationAttemptInstance] VerificationAttemptInstance
219
+ def initialize(version, payload, sid: nil)
220
+ super(version)
221
+
222
+ # Marshaled Properties
223
+ @properties = {
224
+ 'sid' => payload['sid'],
225
+ 'account_sid' => payload['account_sid'],
226
+ 'service_sid' => payload['service_sid'],
227
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
228
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
229
+ 'conversion_status' => payload['conversion_status'],
230
+ 'channel' => payload['channel'],
231
+ 'channel_data' => payload['channel_data'],
232
+ 'url' => payload['url'],
233
+ }
234
+
235
+ # Context
236
+ @instance_context = nil
237
+ @params = {'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 [VerificationAttemptContext] VerificationAttemptContext for this VerificationAttemptInstance
244
+ def context
245
+ unless @instance_context
246
+ @instance_context = VerificationAttemptContext.new(@version, @params['sid'], )
247
+ end
248
+ @instance_context
249
+ end
250
+
251
+ ##
252
+ # @return [String] A string that uniquely identifies this Verification Attempt
253
+ def sid
254
+ @properties['sid']
255
+ end
256
+
257
+ ##
258
+ # @return [String] Account Sid
259
+ def account_sid
260
+ @properties['account_sid']
261
+ end
262
+
263
+ ##
264
+ # @return [String] The service_sid
265
+ def service_sid
266
+ @properties['service_sid']
267
+ end
268
+
269
+ ##
270
+ # @return [Time] The date this Attempt was created
271
+ def date_created
272
+ @properties['date_created']
273
+ end
274
+
275
+ ##
276
+ # @return [Time] The date this Attempt was updated
277
+ def date_updated
278
+ @properties['date_updated']
279
+ end
280
+
281
+ ##
282
+ # @return [verification_attempt.ConversionStatus] Status of a conversion
283
+ def conversion_status
284
+ @properties['conversion_status']
285
+ end
286
+
287
+ ##
288
+ # @return [verification_attempt.Channels] Channel used for the attempt
289
+ def channel
290
+ @properties['channel']
291
+ end
292
+
293
+ ##
294
+ # @return [Hash] Object with the channel information for an attempt
295
+ def channel_data
296
+ @properties['channel_data']
297
+ end
298
+
299
+ ##
300
+ # @return [String] The url
301
+ def url
302
+ @properties['url']
303
+ end
304
+
305
+ ##
306
+ # Fetch the VerificationAttemptInstance
307
+ # @return [VerificationAttemptInstance] Fetched VerificationAttemptInstance
308
+ def fetch
309
+ context.fetch
310
+ end
311
+
312
+ ##
313
+ # Provide a user friendly representation
314
+ def to_s
315
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
316
+ "<Twilio.Verify.V2.VerificationAttemptInstance #{values}>"
317
+ end
318
+
319
+ ##
320
+ # Provide a detailed, user friendly representation
321
+ def inspect
322
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
323
+ "<Twilio.Verify.V2.VerificationAttemptInstance #{values}>"
324
+ end
325
+ end
326
+ end
327
+ end
328
+ end
329
+ end