bandwidth-sdk 17.0.0 → 17.0.1

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.
Files changed (44) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +3 -3
  3. data/README.md +11 -3
  4. data/bandwidth.yml +78 -22
  5. data/coverage/.last_run.json +1 -1
  6. data/coverage/.resultset.json +115 -96
  7. data/coverage/index.html +660 -390
  8. data/docs/MultiChannelAction.md +32 -81
  9. data/docs/MultiChannelApi.md +1 -1
  10. data/docs/{MultiChannelChannelListObject.md → MultiChannelChannelListMMSObject.md} +3 -3
  11. data/docs/{MultiChannelMessageResponseDataChannelListInner.md → MultiChannelChannelListMMSResponseObject.md} +3 -3
  12. data/docs/MultiChannelChannelListObjectBase.md +22 -0
  13. data/docs/MultiChannelChannelListOwnerObject.md +18 -0
  14. data/docs/MultiChannelChannelListRBMObject.md +24 -0
  15. data/docs/{MultiChannelChannelListObjectContent.md → MultiChannelChannelListRBMObjectAllOfContent.md} +6 -10
  16. data/docs/MultiChannelChannelListRBMResponseObject.md +26 -0
  17. data/docs/MultiChannelChannelListRequestObject.md +24 -0
  18. data/docs/MultiChannelChannelListResponseObject.md +26 -0
  19. data/docs/MultiChannelChannelListSMSObject.md +24 -0
  20. data/docs/MultiChannelChannelListSMSResponseObject.md +26 -0
  21. data/docs/MultiChannelMessageRequest.md +1 -1
  22. data/docs/MultiChannelMessageResponseData.md +1 -1
  23. data/docs/RbmActionBase.md +1 -1
  24. data/docs/RbmSuggestionResponse.md +1 -1
  25. data/lib/bandwidth-sdk/models/multi_channel_action.rb +71 -26
  26. data/lib/bandwidth-sdk/models/{multi_channel_channel_list_object.rb → multi_channel_channel_list_mms_object.rb} +11 -4
  27. data/lib/bandwidth-sdk/models/{multi_channel_message_response_data_channel_list_inner.rb → multi_channel_channel_list_mms_response_object.rb} +6 -5
  28. data/lib/bandwidth-sdk/models/multi_channel_channel_list_object_base.rb +275 -0
  29. data/lib/bandwidth-sdk/models/multi_channel_channel_list_owner_object.rb +220 -0
  30. data/lib/bandwidth-sdk/models/multi_channel_channel_list_rbm_object.rb +298 -0
  31. data/lib/bandwidth-sdk/models/{multi_channel_channel_list_object_content.rb → multi_channel_channel_list_rbm_object_all_of_content.rb} +2 -4
  32. data/lib/bandwidth-sdk/models/multi_channel_channel_list_rbm_response_object.rb +316 -0
  33. data/lib/bandwidth-sdk/models/multi_channel_channel_list_request_object.rb +104 -0
  34. data/lib/bandwidth-sdk/models/multi_channel_channel_list_response_object.rb +104 -0
  35. data/lib/bandwidth-sdk/models/multi_channel_channel_list_sms_object.rb +298 -0
  36. data/lib/bandwidth-sdk/models/multi_channel_channel_list_sms_response_object.rb +316 -0
  37. data/lib/bandwidth-sdk/models/multi_channel_message_request.rb +1 -1
  38. data/lib/bandwidth-sdk/models/multi_channel_message_response_data.rb +1 -1
  39. data/lib/bandwidth-sdk/version.rb +1 -1
  40. data/lib/bandwidth-sdk.rb +11 -3
  41. data/spec/smoke/multi_channel_api_spec.rb +124 -23
  42. data/spec/smoke/phone_number_lookup_api_spec.rb +1 -1
  43. data/spec/unit/api/multi_channel_api_spec.rb +13 -2
  44. metadata +24 -8
@@ -0,0 +1,316 @@
1
+ =begin
2
+ #Bandwidth
3
+
4
+ #Bandwidth's Communication APIs
5
+
6
+ The version of the OpenAPI document: 1.0.0
7
+ Contact: letstalk@bandwidth.com
8
+ Generated by: https://openapi-generator.tech
9
+ Generator version: 7.8.0
10
+
11
+ =end
12
+
13
+ require 'date'
14
+ require 'time'
15
+
16
+ module Bandwidth
17
+ class MultiChannelChannelListSMSResponseObject
18
+ # The sender ID of the message. This could be an alphanumeric sender ID.
19
+ attr_accessor :from
20
+
21
+ # The ID of the Application your from number or senderId is associated with in the Bandwidth Phone Number Dashboard.
22
+ attr_accessor :application_id
23
+
24
+ attr_accessor :channel
25
+
26
+ attr_accessor :content
27
+
28
+ # The Bandwidth senderId associated with the message. Identical to 'from'.
29
+ attr_accessor :owner
30
+
31
+ class EnumAttributeValidator
32
+ attr_reader :datatype
33
+ attr_reader :allowable_values
34
+
35
+ def initialize(datatype, allowable_values)
36
+ @allowable_values = allowable_values.map do |value|
37
+ case datatype.to_s
38
+ when /Integer/i
39
+ value.to_i
40
+ when /Float/i
41
+ value.to_f
42
+ else
43
+ value
44
+ end
45
+ end
46
+ end
47
+
48
+ def valid?(value)
49
+ !value || allowable_values.include?(value)
50
+ end
51
+ end
52
+
53
+ # Attribute mapping from ruby-style variable name to JSON key.
54
+ def self.attribute_map
55
+ {
56
+ :'from' => :'from',
57
+ :'application_id' => :'applicationId',
58
+ :'channel' => :'channel',
59
+ :'content' => :'content',
60
+ :'owner' => :'owner'
61
+ }
62
+ end
63
+
64
+ # Returns all the JSON keys this model knows about
65
+ def self.acceptable_attributes
66
+ attribute_map.values
67
+ end
68
+
69
+ # Attribute type mapping.
70
+ def self.openapi_types
71
+ {
72
+ :'from' => :'String',
73
+ :'application_id' => :'String',
74
+ :'channel' => :'MultiChannelMessageChannelEnum',
75
+ :'content' => :'SmsMessageContent',
76
+ :'owner' => :'String'
77
+ }
78
+ end
79
+
80
+ # List of attributes with nullable: true
81
+ def self.openapi_nullable
82
+ Set.new([
83
+ ])
84
+ end
85
+
86
+ # List of class defined in allOf (OpenAPI v3)
87
+ def self.openapi_all_of
88
+ [
89
+ :'MultiChannelChannelListOwnerObject',
90
+ :'MultiChannelChannelListSMSObject'
91
+ ]
92
+ end
93
+
94
+ # Initializes the object
95
+ # @param [Hash] attributes Model attributes in the form of hash
96
+ def initialize(attributes = {})
97
+ if (!attributes.is_a?(Hash))
98
+ fail ArgumentError, 'The input argument (attributes) must be a hash in `Bandwidth::MultiChannelChannelListSMSResponseObject` initialize method'
99
+ end
100
+
101
+ # check to see if the attribute exists and convert string to symbol for hash key
102
+ attributes = attributes.each_with_object({}) { |(k, v), h|
103
+ if (!self.class.attribute_map.key?(k.to_sym))
104
+ fail ArgumentError, "`#{k}` is not a valid attribute in `Bandwidth::MultiChannelChannelListSMSResponseObject`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
105
+ end
106
+ h[k.to_sym] = v
107
+ }
108
+
109
+ if attributes.key?(:'from')
110
+ self.from = attributes[:'from']
111
+ else
112
+ self.from = nil
113
+ end
114
+
115
+ if attributes.key?(:'application_id')
116
+ self.application_id = attributes[:'application_id']
117
+ else
118
+ self.application_id = nil
119
+ end
120
+
121
+ if attributes.key?(:'channel')
122
+ self.channel = attributes[:'channel']
123
+ else
124
+ self.channel = nil
125
+ end
126
+
127
+ if attributes.key?(:'content')
128
+ self.content = attributes[:'content']
129
+ else
130
+ self.content = nil
131
+ end
132
+
133
+ if attributes.key?(:'owner')
134
+ self.owner = attributes[:'owner']
135
+ else
136
+ self.owner = nil
137
+ end
138
+ end
139
+
140
+ # Show invalid properties with the reasons. Usually used together with valid?
141
+ # @return Array for valid properties with the reasons
142
+ def list_invalid_properties
143
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
144
+ invalid_properties = Array.new
145
+ if @from.nil?
146
+ invalid_properties.push('invalid value for "from", from cannot be nil.')
147
+ end
148
+
149
+ if @application_id.nil?
150
+ invalid_properties.push('invalid value for "application_id", application_id cannot be nil.')
151
+ end
152
+
153
+ if @channel.nil?
154
+ invalid_properties.push('invalid value for "channel", channel cannot be nil.')
155
+ end
156
+
157
+ if @content.nil?
158
+ invalid_properties.push('invalid value for "content", content cannot be nil.')
159
+ end
160
+
161
+ if @owner.nil?
162
+ invalid_properties.push('invalid value for "owner", owner cannot be nil.')
163
+ end
164
+
165
+ invalid_properties
166
+ end
167
+
168
+ # Check to see if the all the properties in the model are valid
169
+ # @return true if the model is valid
170
+ def valid?
171
+ warn '[DEPRECATED] the `valid?` method is obsolete'
172
+ return false if @from.nil?
173
+ return false if @application_id.nil?
174
+ return false if @channel.nil?
175
+ return false if @content.nil?
176
+ return false if @owner.nil?
177
+ true
178
+ end
179
+
180
+ # Checks equality by comparing each attribute.
181
+ # @param [Object] Object to be compared
182
+ def ==(o)
183
+ return true if self.equal?(o)
184
+ self.class == o.class &&
185
+ from == o.from &&
186
+ application_id == o.application_id &&
187
+ channel == o.channel &&
188
+ content == o.content &&
189
+ owner == o.owner
190
+ end
191
+
192
+ # @see the `==` method
193
+ # @param [Object] Object to be compared
194
+ def eql?(o)
195
+ self == o
196
+ end
197
+
198
+ # Calculates hash code according to all attributes.
199
+ # @return [Integer] Hash code
200
+ def hash
201
+ [from, application_id, channel, content, owner].hash
202
+ end
203
+
204
+ # Builds the object from hash
205
+ # @param [Hash] attributes Model attributes in the form of hash
206
+ # @return [Object] Returns the model itself
207
+ def self.build_from_hash(attributes)
208
+ return nil unless attributes.is_a?(Hash)
209
+ attributes = attributes.transform_keys(&:to_sym)
210
+ transformed_hash = {}
211
+ openapi_types.each_pair do |key, type|
212
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
213
+ transformed_hash["#{key}"] = nil
214
+ elsif type =~ /\AArray<(.*)>/i
215
+ # check to ensure the input is an array given that the attribute
216
+ # is documented as an array but the input is not
217
+ if attributes[attribute_map[key]].is_a?(Array)
218
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
219
+ end
220
+ elsif !attributes[attribute_map[key]].nil?
221
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
222
+ end
223
+ end
224
+ new(transformed_hash)
225
+ end
226
+
227
+ # Deserializes the data based on type
228
+ # @param string type Data type
229
+ # @param string value Value to be deserialized
230
+ # @return [Object] Deserialized data
231
+ def self._deserialize(type, value)
232
+ case type.to_sym
233
+ when :Time
234
+ Time.parse(value)
235
+ when :Date
236
+ Date.parse(value)
237
+ when :String
238
+ value.to_s
239
+ when :Integer
240
+ value.to_i
241
+ when :Float
242
+ value.to_f
243
+ when :Boolean
244
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
245
+ true
246
+ else
247
+ false
248
+ end
249
+ when :Object
250
+ # generic object (usually a Hash), return directly
251
+ value
252
+ when /\AArray<(?<inner_type>.+)>\z/
253
+ inner_type = Regexp.last_match[:inner_type]
254
+ value.map { |v| _deserialize(inner_type, v) }
255
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
256
+ k_type = Regexp.last_match[:k_type]
257
+ v_type = Regexp.last_match[:v_type]
258
+ {}.tap do |hash|
259
+ value.each do |k, v|
260
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
261
+ end
262
+ end
263
+ else # model
264
+ # models (e.g. Pet) or oneOf
265
+ klass = Bandwidth.const_get(type)
266
+ klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
267
+ end
268
+ end
269
+
270
+ # Returns the string representation of the object
271
+ # @return [String] String presentation of the object
272
+ def to_s
273
+ to_hash.to_s
274
+ end
275
+
276
+ # to_body is an alias to to_hash (backward compatibility)
277
+ # @return [Hash] Returns the object in the form of hash
278
+ def to_body
279
+ to_hash
280
+ end
281
+
282
+ # Returns the object in the form of hash
283
+ # @return [Hash] Returns the object in the form of hash
284
+ def to_hash
285
+ hash = {}
286
+ self.class.attribute_map.each_pair do |attr, param|
287
+ value = self.send(attr)
288
+ if value.nil?
289
+ is_nullable = self.class.openapi_nullable.include?(attr)
290
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
291
+ end
292
+
293
+ hash[param] = _to_hash(value)
294
+ end
295
+ hash
296
+ end
297
+
298
+ # Outputs non-array value in the form of hash
299
+ # For object, use to_hash. Otherwise, just return the value
300
+ # @param [Object] value Any valid value
301
+ # @return [Hash] Returns the value in the form of hash
302
+ def _to_hash(value)
303
+ if value.is_a?(Array)
304
+ value.compact.map { |v| _to_hash(v) }
305
+ elsif value.is_a?(Hash)
306
+ {}.tap do |hash|
307
+ value.each { |k, v| hash[k] = _to_hash(v) }
308
+ end
309
+ elsif value.respond_to? :to_hash
310
+ value.to_hash
311
+ else
312
+ value
313
+ end
314
+ end
315
+ end
316
+ end
@@ -72,7 +72,7 @@ module Bandwidth
72
72
  def self.openapi_types
73
73
  {
74
74
  :'to' => :'String',
75
- :'channel_list' => :'Array<MultiChannelChannelListObject>',
75
+ :'channel_list' => :'Array<MultiChannelChannelListRequestObject>',
76
76
  :'tag' => :'String',
77
77
  :'priority' => :'PriorityEnum',
78
78
  :'expiration' => :'Time'
@@ -86,7 +86,7 @@ module Bandwidth
86
86
  :'time' => :'Time',
87
87
  :'direction' => :'MessageDirectionEnum',
88
88
  :'to' => :'Array<String>',
89
- :'channel_list' => :'Array<MultiChannelMessageResponseDataChannelListInner>',
89
+ :'channel_list' => :'Array<MultiChannelChannelListResponseObject>',
90
90
  :'tag' => :'String',
91
91
  :'priority' => :'PriorityEnum',
92
92
  :'expiration' => :'Time'
@@ -11,5 +11,5 @@ Generator version: 7.8.0
11
11
  =end
12
12
 
13
13
  module Bandwidth
14
- VERSION = '17.0.0'
14
+ VERSION = '17.0.1'
15
15
  end
data/lib/bandwidth-sdk.rb CHANGED
@@ -109,14 +109,22 @@ require 'bandwidth-sdk/models/mms_message_content'
109
109
  require 'bandwidth-sdk/models/mms_message_content_file'
110
110
  require 'bandwidth-sdk/models/multi_channel_action'
111
111
  require 'bandwidth-sdk/models/multi_channel_action_calendar_event'
112
- require 'bandwidth-sdk/models/multi_channel_channel_list_object'
113
- require 'bandwidth-sdk/models/multi_channel_channel_list_object_content'
112
+ require 'bandwidth-sdk/models/multi_channel_channel_list_mms_object'
113
+ require 'bandwidth-sdk/models/multi_channel_channel_list_mms_response_object'
114
+ require 'bandwidth-sdk/models/multi_channel_channel_list_object_base'
115
+ require 'bandwidth-sdk/models/multi_channel_channel_list_owner_object'
116
+ require 'bandwidth-sdk/models/multi_channel_channel_list_rbm_object'
117
+ require 'bandwidth-sdk/models/multi_channel_channel_list_rbm_object_all_of_content'
118
+ require 'bandwidth-sdk/models/multi_channel_channel_list_rbm_response_object'
119
+ require 'bandwidth-sdk/models/multi_channel_channel_list_request_object'
120
+ require 'bandwidth-sdk/models/multi_channel_channel_list_response_object'
121
+ require 'bandwidth-sdk/models/multi_channel_channel_list_sms_object'
122
+ require 'bandwidth-sdk/models/multi_channel_channel_list_sms_response_object'
114
123
  require 'bandwidth-sdk/models/multi_channel_error'
115
124
  require 'bandwidth-sdk/models/multi_channel_message_channel_enum'
116
125
  require 'bandwidth-sdk/models/multi_channel_message_content'
117
126
  require 'bandwidth-sdk/models/multi_channel_message_request'
118
127
  require 'bandwidth-sdk/models/multi_channel_message_response_data'
119
- require 'bandwidth-sdk/models/multi_channel_message_response_data_channel_list_inner'
120
128
  require 'bandwidth-sdk/models/opt_in_workflow'
121
129
  require 'bandwidth-sdk/models/page_info'
122
130
  require 'bandwidth-sdk/models/priority_enum'
@@ -10,29 +10,130 @@ describe 'MultiChannelApi' do
10
10
  @expiration_time = (Time.now + 60).round.to_datetime.rfc3339
11
11
  end
12
12
 
13
- # Create Multi-Channel Message
14
- describe 'create_multi_channel_message' do
15
- it 'creates a multi channel message' do
16
- message_body = Bandwidth::MultiChannelChannelListObject.new(
17
- from: BW_NUMBER,
18
- application_id: BW_MESSAGING_APPLICATION_ID,
19
- channel: Bandwidth::MultiChannelMessageChannelEnum::RBM,
20
- content: Bandwidth::RbmMessageContentText.new(
21
- text: 'Hello, this is a test message.',
13
+ # Create Multi-Channel SMS Message
14
+ describe 'create_multi_channel_sms_message' do
15
+ it 'creates a multi channel sms message' do
16
+ message_body = Bandwidth::MultiChannelChannelListSMSObject.new(
17
+ from: BW_NUMBER,
18
+ application_id: BW_MESSAGING_APPLICATION_ID,
19
+ channel: Bandwidth::MultiChannelMessageChannelEnum::SMS,
20
+ content: Bandwidth::SmsMessageContent.new(
21
+ text: 'Hello, this is a test message.',
22
+ )
22
23
  )
23
- )
24
- multi_channel_message_request = Bandwidth::MultiChannelMessageRequest.new(
25
- to: USER_NUMBER,
26
- channel_list: [message_body],
27
- tag: 'tag',
28
- priority: 'high',
29
- expiration: @expiration_time,
30
- )
31
-
32
- data, status_code = @multi_channel_api_instance.create_multi_channel_message_with_http_info(BW_ACCOUNT_ID, multi_channel_message_request)
33
-
34
- expect(status_code).to eq(202)
35
- expect(data).to be_instance_of(Bandwidth::CreateMultiChannelMessageResponse)
36
- end if false # skip while still in beta
24
+ multi_channel_message_request = Bandwidth::MultiChannelMessageRequest.new(
25
+ to: USER_NUMBER,
26
+ channel_list: [message_body],
27
+ tag: 'tag',
28
+ priority: 'high',
29
+ expiration: @expiration_time,
30
+ )
31
+
32
+ data, status_code = @multi_channel_api_instance.create_multi_channel_message_with_http_info(BW_ACCOUNT_ID, multi_channel_message_request)
33
+
34
+ expect(status_code).to eq(202)
35
+ p data.data
36
+ expect(data).to be_instance_of(Bandwidth::CreateMultiChannelMessageResponse)
37
+ expect(data.links).to be_instance_of(Array)
38
+ expect(data.data).to be_instance_of(Bandwidth::MultiChannelMessageResponseData)
39
+ expect(data.data.id).to be_instance_of(String)
40
+ expect(data.data.time).to be_instance_of(Time)
41
+ expect(data.data.direction).to be_one_of(Bandwidth::MessageDirectionEnum.all_vars)
42
+ expect(data.data.to).to be_instance_of(Array)
43
+ expect(data.data.tag).to be_instance_of(String)
44
+ expect(data.data.priority).to be_one_of(Bandwidth::PriorityEnum.all_vars)
45
+ expect(data.data.expiration).to be_instance_of(Time)
46
+ expect(data.data.channel_list).to be_instance_of(Array)
47
+ # add more assertions once SDK supports discriminators
48
+ end
49
+ end
50
+
51
+ # Create Multi-Channel MMS Message
52
+ describe 'create_multi_channel_mms_message' do
53
+ it 'creates a multi channel mms message' do
54
+ message_body = Bandwidth::MultiChannelChannelListMMSObject.new(
55
+ from: BW_NUMBER,
56
+ application_id: BW_MESSAGING_APPLICATION_ID,
57
+ channel: Bandwidth::MultiChannelMessageChannelEnum::MMS,
58
+ content: Bandwidth::MmsMessageContent.new(
59
+ media: [
60
+ Bandwidth::MmsMessageContentFile.new(
61
+ file_url: 'https://example.com/image.jpg'
62
+ )
63
+ ],
64
+ text: 'Hello, this is a test message.',
65
+ )
66
+ )
67
+ multi_channel_message_request = Bandwidth::MultiChannelMessageRequest.new(
68
+ to: USER_NUMBER,
69
+ channel_list: [message_body],
70
+ tag: 'tag',
71
+ priority: 'high',
72
+ expiration: @expiration_time,
73
+ )
74
+
75
+ data, status_code = @multi_channel_api_instance.create_multi_channel_message_with_http_info(BW_ACCOUNT_ID, multi_channel_message_request)
76
+
77
+ expect(status_code).to eq(202)
78
+ p data.data
79
+ expect(data).to be_instance_of(Bandwidth::CreateMultiChannelMessageResponse)
80
+ expect(data.links).to be_instance_of(Array)
81
+ expect(data.data).to be_instance_of(Bandwidth::MultiChannelMessageResponseData)
82
+ expect(data.data.id).to be_instance_of(String)
83
+ expect(data.data.time).to be_instance_of(Time)
84
+ expect(data.data.direction).to be_one_of(Bandwidth::MessageDirectionEnum.all_vars)
85
+ expect(data.data.to).to be_instance_of(Array)
86
+ expect(data.data.tag).to be_instance_of(String)
87
+ expect(data.data.priority).to be_one_of(Bandwidth::PriorityEnum.all_vars)
88
+ expect(data.data.expiration).to be_instance_of(Time)
89
+ expect(data.data.channel_list).to be_instance_of(Array)
90
+ # add more assertions once SDK supports discriminators
91
+ end
92
+ end
93
+
94
+ # Create Multi-Channel RBM Message
95
+ describe 'create_multi_channel_rbm_message' do
96
+ it 'creates a multi channel rbm message' do
97
+ message_body = Bandwidth::MultiChannelChannelListRBMObject.new(
98
+ from: BW_NUMBER,
99
+ application_id: BW_MESSAGING_APPLICATION_ID,
100
+ channel: Bandwidth::MultiChannelMessageChannelEnum::RBM,
101
+ content: Bandwidth::RbmMessageContentText.new(
102
+ text: 'Hello, this is a test message.',
103
+ suggestions: [
104
+ Bandwidth::RbmActionDial.new(
105
+ type: Bandwidth::RbmActionTypeEnum::DIAL_PHONE,
106
+ text: 'Call Us',
107
+ postback_data: 'abcdefg12345678',
108
+ phone_number: BW_NUMBER
109
+ )
110
+ ]
111
+ )
112
+ )
113
+ multi_channel_message_request = Bandwidth::MultiChannelMessageRequest.new(
114
+ to: USER_NUMBER,
115
+ channel_list: [message_body],
116
+ tag: 'tag',
117
+ priority: 'high',
118
+ expiration: @expiration_time,
119
+ )
120
+
121
+ data, status_code = @multi_channel_api_instance.create_multi_channel_message_with_http_info(BW_ACCOUNT_ID, multi_channel_message_request)
122
+
123
+ expect(status_code).to eq(202)
124
+ p data.data
125
+ expect(data).to be_instance_of(Bandwidth::CreateMultiChannelMessageResponse)
126
+ expect(data.links).to be_instance_of(Array)
127
+ expect(data.data).to be_instance_of(Bandwidth::MultiChannelMessageResponseData)
128
+ expect(data.data.id).to be_instance_of(String)
129
+ expect(data.data.time).to be_instance_of(Time)
130
+ expect(data.data.direction).to be_one_of(Bandwidth::MessageDirectionEnum.all_vars)
131
+ expect(data.data.to).to be_instance_of(Array)
132
+ expect(data.data.tag).to be_instance_of(String)
133
+ expect(data.data.priority).to be_one_of(Bandwidth::PriorityEnum.all_vars)
134
+ expect(data.data.expiration).to be_instance_of(Time)
135
+ expect(data.data.channel_list).to be_instance_of(Array)
136
+ # add more assertions once SDK supports discriminators
137
+ end
37
138
  end
38
139
  end
@@ -36,7 +36,7 @@ describe 'PhoneNumberLookupApi' do
36
36
  expect(create_data.errors).to be_instance_of(Array)
37
37
 
38
38
  request_id = create_data.data.request_id
39
- sleep(10)
39
+ sleep(30)
40
40
 
41
41
  get_data, get_status_code = @api_instance.get_async_bulk_lookup_with_http_info(BW_ACCOUNT_ID, request_id)
42
42
  expect(get_status_code).to equal_to(200)
@@ -22,7 +22,7 @@ describe 'MultiChannelApi' do
22
22
  # Create Multi-Channel Message
23
23
  describe 'create_multi_channel_message' do
24
24
  it 'creates a multi channel message' do
25
- message_body = Bandwidth::MultiChannelChannelListObject.new(
25
+ message_body = Bandwidth::MultiChannelChannelListSMSObject.new(
26
26
  from: BW_NUMBER,
27
27
  application_id: BW_MESSAGING_APPLICATION_ID,
28
28
  channel: Bandwidth::MultiChannelMessageChannelEnum::SMS,
@@ -30,6 +30,7 @@ describe 'MultiChannelApi' do
30
30
  text: 'Hello, this is a test message.',
31
31
  )
32
32
  )
33
+
33
34
  multi_channel_message_request = Bandwidth::MultiChannelMessageRequest.new(
34
35
  to: USER_NUMBER,
35
36
  channel_list: [message_body],
@@ -42,7 +43,17 @@ describe 'MultiChannelApi' do
42
43
 
43
44
  expect(status_code).to eq(202)
44
45
  expect(data).to be_instance_of(Bandwidth::CreateMultiChannelMessageResponse)
45
- end if false # skip because prism can't handle a oneOf with differing required fields
46
+ expect(data.links).to be_instance_of(Array)
47
+ expect(data.data).to be_instance_of(Bandwidth::MultiChannelMessageResponseData)
48
+ expect(data.data.id).to be_instance_of(String)
49
+ expect(data.data.time).to be_instance_of(Time)
50
+ expect(data.data.direction).to be_one_of(Bandwidth::MessageDirectionEnum.all_vars)
51
+ expect(data.data.to).to be_instance_of(Array)
52
+ expect(data.data.tag).to be_instance_of(String)
53
+ expect(data.data.priority).to be_one_of(Bandwidth::PriorityEnum.all_vars)
54
+ expect(data.data.expiration).to be_instance_of(Time)
55
+ expect(data.data.channel_list).to be_instance_of(Array)
56
+ end
46
57
 
47
58
  it 'causes an ArgumentError for a missing account_id' do
48
59
  expect {
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bandwidth-sdk
3
3
  version: !ruby/object:Gem::Version
4
- version: 17.0.0
4
+ version: 17.0.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Bandwidth
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-11-11 00:00:00.000000000 Z
11
+ date: 2025-11-25 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: faraday
@@ -241,14 +241,22 @@ files:
241
241
  - docs/MultiChannelAction.md
242
242
  - docs/MultiChannelActionCalendarEvent.md
243
243
  - docs/MultiChannelApi.md
244
- - docs/MultiChannelChannelListObject.md
245
- - docs/MultiChannelChannelListObjectContent.md
244
+ - docs/MultiChannelChannelListMMSObject.md
245
+ - docs/MultiChannelChannelListMMSResponseObject.md
246
+ - docs/MultiChannelChannelListObjectBase.md
247
+ - docs/MultiChannelChannelListOwnerObject.md
248
+ - docs/MultiChannelChannelListRBMObject.md
249
+ - docs/MultiChannelChannelListRBMObjectAllOfContent.md
250
+ - docs/MultiChannelChannelListRBMResponseObject.md
251
+ - docs/MultiChannelChannelListRequestObject.md
252
+ - docs/MultiChannelChannelListResponseObject.md
253
+ - docs/MultiChannelChannelListSMSObject.md
254
+ - docs/MultiChannelChannelListSMSResponseObject.md
246
255
  - docs/MultiChannelError.md
247
256
  - docs/MultiChannelMessageChannelEnum.md
248
257
  - docs/MultiChannelMessageContent.md
249
258
  - docs/MultiChannelMessageRequest.md
250
259
  - docs/MultiChannelMessageResponseData.md
251
- - docs/MultiChannelMessageResponseDataChannelListInner.md
252
260
  - docs/OptInWorkflow.md
253
261
  - docs/PageInfo.md
254
262
  - docs/PhoneNumberLookupApi.md
@@ -461,14 +469,22 @@ files:
461
469
  - lib/bandwidth-sdk/models/mms_message_content_file.rb
462
470
  - lib/bandwidth-sdk/models/multi_channel_action.rb
463
471
  - lib/bandwidth-sdk/models/multi_channel_action_calendar_event.rb
464
- - lib/bandwidth-sdk/models/multi_channel_channel_list_object.rb
465
- - lib/bandwidth-sdk/models/multi_channel_channel_list_object_content.rb
472
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_mms_object.rb
473
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_mms_response_object.rb
474
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_object_base.rb
475
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_owner_object.rb
476
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_rbm_object.rb
477
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_rbm_object_all_of_content.rb
478
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_rbm_response_object.rb
479
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_request_object.rb
480
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_response_object.rb
481
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_sms_object.rb
482
+ - lib/bandwidth-sdk/models/multi_channel_channel_list_sms_response_object.rb
466
483
  - lib/bandwidth-sdk/models/multi_channel_error.rb
467
484
  - lib/bandwidth-sdk/models/multi_channel_message_channel_enum.rb
468
485
  - lib/bandwidth-sdk/models/multi_channel_message_content.rb
469
486
  - lib/bandwidth-sdk/models/multi_channel_message_request.rb
470
487
  - lib/bandwidth-sdk/models/multi_channel_message_response_data.rb
471
- - lib/bandwidth-sdk/models/multi_channel_message_response_data_channel_list_inner.rb
472
488
  - lib/bandwidth-sdk/models/opt_in_workflow.rb
473
489
  - lib/bandwidth-sdk/models/page_info.rb
474
490
  - lib/bandwidth-sdk/models/priority_enum.rb