mux_ruby 4.0.0 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +1 -1
  3. data/README.md +4 -4
  4. data/docs/Asset.md +4 -2
  5. data/docs/AssetMetadata.md +22 -0
  6. data/docs/CreateAssetRequest.md +11 -5
  7. data/docs/CreateLiveStreamRequest.md +4 -2
  8. data/docs/PlaybackRestrictionsApi.md +1 -1
  9. data/docs/UpdateAssetRequest.md +4 -2
  10. data/docs/UpdateLiveStreamNewAssetSettings.md +3 -1
  11. data/docs/UpdateReferrerDomainRestrictionRequest.md +10 -37
  12. data/docs/Upload.md +1 -1
  13. data/docs/VideoView.md +3 -1
  14. data/examples/video/exercise-assets.rb +1 -1
  15. data/gen/generator-config.json +1 -1
  16. data/lib/mux_ruby/api/metrics_api.rb +2 -2
  17. data/lib/mux_ruby/models/asset.rb +14 -5
  18. data/lib/mux_ruby/models/asset_metadata.rb +284 -0
  19. data/lib/mux_ruby/models/create_asset_request.rb +41 -8
  20. data/lib/mux_ruby/models/create_live_stream_request.rb +15 -2
  21. data/lib/mux_ruby/models/update_asset_request.rb +14 -5
  22. data/lib/mux_ruby/models/update_live_stream_new_asset_settings.rb +13 -4
  23. data/lib/mux_ruby/models/update_referrer_domain_restriction_request.rb +203 -73
  24. data/lib/mux_ruby/models/upload.rb +1 -1
  25. data/lib/mux_ruby/models/video_view.rb +15 -5
  26. data/lib/mux_ruby/version.rb +1 -1
  27. data/lib/mux_ruby.rb +1 -0
  28. data/spec/models/asset_metadata_spec.rb +46 -0
  29. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/byebug-11.1.3/byebug/byebug.so +0 -0
  30. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/byebug-11.1.3/gem_make.out +6 -6
  31. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/ffi-1.16.3/ffi_c.so +0 -0
  32. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/ffi-1.16.3/gem_make.out +6 -6
  33. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/ffi-1.16.3/mkmf.log +16 -16
  34. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/jaro_winkler-1.5.6/gem_make.out +6 -6
  35. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/jaro_winkler-1.5.6/jaro_winkler/jaro_winkler_ext.so +0 -0
  36. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/psych-4.0.4/gem_make.out +6 -6
  37. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/psych-4.0.4/mkmf.log +4 -4
  38. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/psych-4.0.4/psych.so +0 -0
  39. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/stringio-3.0.2/gem_make.out +6 -6
  40. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/stringio-3.0.2/mkmf.log +2 -2
  41. data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/stringio-3.0.2/stringio.so +0 -0
  42. data/vendor/bundle/ruby/3.2.0/gems/byebug-11.1.3/ext/byebug/Makefile +3 -3
  43. data/vendor/bundle/ruby/3.2.0/gems/byebug-11.1.3/lib/byebug/byebug.so +0 -0
  44. data/vendor/bundle/ruby/3.2.0/gems/ffi-1.16.3/ext/ffi_c/Makefile +3 -3
  45. data/vendor/bundle/ruby/3.2.0/gems/ffi-1.16.3/lib/ffi_c.so +0 -0
  46. data/vendor/bundle/ruby/3.2.0/gems/jaro_winkler-1.5.6/ext/jaro_winkler/Makefile +3 -3
  47. data/vendor/bundle/ruby/3.2.0/gems/jaro_winkler-1.5.6/lib/jaro_winkler/jaro_winkler_ext.so +0 -0
  48. data/vendor/bundle/ruby/3.2.0/gems/psych-4.0.4/ext/psych/Makefile +3 -3
  49. data/vendor/bundle/ruby/3.2.0/gems/psych-4.0.4/lib/psych.so +0 -0
  50. data/vendor/bundle/ruby/3.2.0/gems/stringio-3.0.2/ext/stringio/Makefile +3 -3
  51. data/vendor/bundle/ruby/3.2.0/gems/stringio-3.0.2/lib/stringio.so +0 -0
  52. metadata +169 -165
@@ -0,0 +1,284 @@
1
+ =begin
2
+ #Mux API
3
+
4
+ #Mux is how developers build online video. This API encompasses both Mux Video and Mux Data functionality to help you build your video-related projects better and faster than ever before.
5
+
6
+ The version of the OpenAPI document: v1
7
+ Contact: devex@mux.com
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.0.1
10
+
11
+ =end
12
+
13
+ require 'date'
14
+ require 'time'
15
+
16
+ module MuxRuby
17
+ class AssetMetadata
18
+ # The video title. Max 512 code points.
19
+ attr_accessor :title
20
+
21
+ # This is an identifier you provide to keep track of the creator of the video. Max 128 code points.
22
+ attr_accessor :creator_id
23
+
24
+ # This is an identifier you provide to link the video to your own data. Max 128 code points.
25
+ attr_accessor :external_id
26
+
27
+ # Attribute mapping from ruby-style variable name to JSON key.
28
+ def self.attribute_map
29
+ {
30
+ :'title' => :'title',
31
+ :'creator_id' => :'creator_id',
32
+ :'external_id' => :'external_id'
33
+ }
34
+ end
35
+
36
+ # Returns all the JSON keys this model knows about
37
+ def self.acceptable_attributes
38
+ attribute_map.values
39
+ end
40
+
41
+ # Attribute type mapping.
42
+ def self.openapi_types
43
+ {
44
+ :'title' => :'String',
45
+ :'creator_id' => :'String',
46
+ :'external_id' => :'String'
47
+ }
48
+ end
49
+
50
+ # List of attributes with nullable: true
51
+ def self.openapi_nullable
52
+ Set.new([
53
+ ])
54
+ end
55
+
56
+ # Initializes the object
57
+ # @param [Hash] attributes Model attributes in the form of hash
58
+ def initialize(attributes = {})
59
+ if (!attributes.is_a?(Hash))
60
+ fail ArgumentError, "The input argument (attributes) must be a hash in `MuxRuby::AssetMetadata` initialize method"
61
+ end
62
+
63
+ # check to see if the attribute exists and convert string to symbol for hash key
64
+ attributes = attributes.each_with_object({}) { |(k, v), h|
65
+ if (!self.class.attribute_map.key?(k.to_sym))
66
+ fail ArgumentError, "`#{k}` is not a valid attribute in `MuxRuby::AssetMetadata`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
67
+ end
68
+ h[k.to_sym] = v
69
+ }
70
+
71
+ if attributes.key?(:'title')
72
+ self.title = attributes[:'title']
73
+ end
74
+
75
+ if attributes.key?(:'creator_id')
76
+ self.creator_id = attributes[:'creator_id']
77
+ end
78
+
79
+ if attributes.key?(:'external_id')
80
+ self.external_id = attributes[:'external_id']
81
+ end
82
+ end
83
+
84
+ # Show invalid properties with the reasons. Usually used together with valid?
85
+ # @return Array for valid properties with the reasons
86
+ def list_invalid_properties
87
+ invalid_properties = Array.new
88
+ if !@title.nil? && @title.to_s.length > 512
89
+ invalid_properties.push('invalid value for "title", the character length must be smaller than or equal to 512.')
90
+ end
91
+
92
+ if !@creator_id.nil? && @creator_id.to_s.length > 128
93
+ invalid_properties.push('invalid value for "creator_id", the character length must be smaller than or equal to 128.')
94
+ end
95
+
96
+ if !@external_id.nil? && @external_id.to_s.length > 128
97
+ invalid_properties.push('invalid value for "external_id", the character length must be smaller than or equal to 128.')
98
+ end
99
+
100
+ invalid_properties
101
+ end
102
+
103
+ # Check to see if the all the properties in the model are valid
104
+ # @return true if the model is valid
105
+ def valid?
106
+ return false if !@title.nil? && @title.to_s.length > 512
107
+ return false if !@creator_id.nil? && @creator_id.to_s.length > 128
108
+ return false if !@external_id.nil? && @external_id.to_s.length > 128
109
+ true
110
+ end
111
+
112
+ # Custom attribute writer method with validation
113
+ # @param [Object] title Value to be assigned
114
+ def title=(title)
115
+ if !title.nil? && title.to_s.length > 512
116
+ fail ArgumentError, 'invalid value for "title", the character length must be smaller than or equal to 512.'
117
+ end
118
+
119
+ @title = title
120
+ end
121
+
122
+ # Custom attribute writer method with validation
123
+ # @param [Object] creator_id Value to be assigned
124
+ def creator_id=(creator_id)
125
+ if !creator_id.nil? && creator_id.to_s.length > 128
126
+ fail ArgumentError, 'invalid value for "creator_id", the character length must be smaller than or equal to 128.'
127
+ end
128
+
129
+ @creator_id = creator_id
130
+ end
131
+
132
+ # Custom attribute writer method with validation
133
+ # @param [Object] external_id Value to be assigned
134
+ def external_id=(external_id)
135
+ if !external_id.nil? && external_id.to_s.length > 128
136
+ fail ArgumentError, 'invalid value for "external_id", the character length must be smaller than or equal to 128.'
137
+ end
138
+
139
+ @external_id = external_id
140
+ end
141
+
142
+ # Checks equality by comparing each attribute.
143
+ # @param [Object] Object to be compared
144
+ def ==(o)
145
+ return true if self.equal?(o)
146
+ self.class == o.class &&
147
+ title == o.title &&
148
+ creator_id == o.creator_id &&
149
+ external_id == o.external_id
150
+ end
151
+
152
+ # @see the `==` method
153
+ # @param [Object] Object to be compared
154
+ def eql?(o)
155
+ self == o
156
+ end
157
+
158
+ # Calculates hash code according to all attributes.
159
+ # @return [Integer] Hash code
160
+ def hash
161
+ [title, creator_id, external_id].hash
162
+ end
163
+
164
+ # Builds the object from hash
165
+ # @param [Hash] attributes Model attributes in the form of hash
166
+ # @return [Object] Returns the model itself
167
+ def self.build_from_hash(attributes)
168
+ new.build_from_hash(attributes)
169
+ end
170
+
171
+ # Builds the object from hash
172
+ # @param [Hash] attributes Model attributes in the form of hash
173
+ # @return [Object] Returns the model itself
174
+ def build_from_hash(attributes)
175
+ return nil unless attributes.is_a?(Hash)
176
+ self.class.openapi_types.each_pair do |key, type|
177
+ if attributes[self.class.attribute_map[key]].nil? && self.class.openapi_nullable.include?(key)
178
+ self.send("#{key}=", nil)
179
+ elsif type =~ /\AArray<(.*)>/i
180
+ # check to ensure the input is an array given that the attribute
181
+ # is documented as an array but the input is not
182
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
183
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
184
+ end
185
+ elsif !attributes[self.class.attribute_map[key]].nil?
186
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
187
+ end
188
+ end
189
+
190
+ self
191
+ end
192
+
193
+ # Deserializes the data based on type
194
+ # @param string type Data type
195
+ # @param string value Value to be deserialized
196
+ # @return [Object] Deserialized data
197
+ def _deserialize(type, value)
198
+ case type.to_sym
199
+ when :Time
200
+ Time.parse(value)
201
+ when :Date
202
+ Date.parse(value)
203
+ when :String
204
+ value.to_s
205
+ when :Integer
206
+ value.to_i
207
+ when :Float
208
+ value.to_f
209
+ when :Boolean
210
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
211
+ true
212
+ else
213
+ false
214
+ end
215
+ when :Object
216
+ # generic object (usually a Hash), return directly
217
+ value
218
+ when /\AArray<(?<inner_type>.+)>\z/
219
+ inner_type = Regexp.last_match[:inner_type]
220
+ value.map { |v| _deserialize(inner_type, v) }
221
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
222
+ k_type = Regexp.last_match[:k_type]
223
+ v_type = Regexp.last_match[:v_type]
224
+ {}.tap do |hash|
225
+ value.each do |k, v|
226
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
227
+ end
228
+ end
229
+ else # model
230
+ # models (e.g. Pet) or oneOf
231
+ klass = MuxRuby.const_get(type)
232
+ klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
233
+ end
234
+ end
235
+
236
+ # Returns the string representation of the object
237
+ # @return [String] String presentation of the object
238
+ def to_s
239
+ to_hash.to_s
240
+ end
241
+
242
+ # to_body is an alias to to_hash (backward compatibility)
243
+ # @return [Hash] Returns the object in the form of hash
244
+ def to_body
245
+ to_hash
246
+ end
247
+
248
+ # Returns the object in the form of hash
249
+ # @return [Hash] Returns the object in the form of hash
250
+ def to_hash
251
+ hash = {}
252
+ self.class.attribute_map.each_pair do |attr, param|
253
+ value = self.send(attr)
254
+ if value.nil?
255
+ is_nullable = self.class.openapi_nullable.include?(attr)
256
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
257
+ end
258
+
259
+ hash[param] = _to_hash(value)
260
+ end
261
+ hash
262
+ end
263
+
264
+ # Outputs non-array value in the form of hash
265
+ # For object, use to_hash. Otherwise, just return the value
266
+ # @param [Object] value Any valid value
267
+ # @return [Hash] Returns the value in the form of hash
268
+ def _to_hash(value)
269
+ if value.is_a?(Array)
270
+ value.compact.map { |v| _to_hash(v) }
271
+ elsif value.is_a?(Hash)
272
+ {}.tap do |hash|
273
+ value.each { |k, v| hash[k] = _to_hash(v) }
274
+ end
275
+ elsif value.respond_to? :to_hash
276
+ value.to_hash
277
+ else
278
+ value
279
+ end
280
+ end
281
+
282
+ end
283
+
284
+ end
@@ -15,18 +15,24 @@ require 'time'
15
15
 
16
16
  module MuxRuby
17
17
  class CreateAssetRequest
18
- # An array of objects that each describe an input file to be used to create the asset. As a shortcut, input can also be a string URL for a file when only one input file is used. See `input[].url` for requirements.
18
+ # Deprecated. Use `inputs` instead, which accepts an identical type.
19
19
  attr_accessor :input
20
20
 
21
- # An array of playback policy names that you want applied to this asset and available through `playback_ids`. Options include: * `\"public\"` (anyone with the playback URL can stream the asset). * `\"signed\"` (an additional access token is required to play the asset). If no `playback_policy` is set, the asset will have no playback IDs and will therefore not be playable. For simplicity, a single string name can be used in place of the array in the case of only one playback policy.
21
+ # An array of objects that each describe an input file to be used to create the asset. As a shortcut, input can also be a string URL for a file when only one input file is used. See `input[].url` for requirements.
22
+ attr_accessor :inputs
23
+
24
+ # Deprecated. Use `playback_policies` instead, which accepts an identical type.
22
25
  attr_accessor :playback_policy
23
26
 
24
- # An array of playback policy objects that you want applied to this asset and available through `playback_ids`. `advanced_playback_policies` must be used instead of `playback_policy` when creating a DRM playback ID.
27
+ # An array of playback policy names that you want applied to this asset and available through `playback_ids`. Options include: * `\"public\"` (anyone with the playback URL can stream the asset). * `\"signed\"` (an additional access token is required to play the asset). If no `playback_policies` are set, the asset will have no playback IDs and will therefore not be playable. For simplicity, a single string name can be used in place of the array in the case of only one playback policy.
28
+ attr_accessor :playback_policies
29
+
30
+ # An array of playback policy objects that you want applied to this asset and available through `playback_ids`. `advanced_playback_policies` must be used instead of `playback_policies` when creating a DRM playback ID.
25
31
  attr_accessor :advanced_playback_policies
26
32
 
27
33
  attr_accessor :per_title_encode
28
34
 
29
- # Arbitrary user-supplied metadata that will be included in the asset details and related webhooks. Can be used to store your own ID for a video along with the asset. **Max: 255 characters**.
35
+ # You can set this field to anything you want. It will be included in the asset details and related webhooks. If you're looking for more structured metadata, such as `title` or `external_id`, you can use the `meta` object instead. **Max: 255 characters**.
30
36
  attr_accessor :passthrough
31
37
 
32
38
  # Deprecated. See the [Static Renditions API](https://www.mux.com/docs/guides/enable-static-mp4-renditions) for the updated API. Specify what level of support for mp4 playback. You may not enable both `mp4_support` and `static_renditions`. * The `capped-1080p` option produces a single MP4 file, called `capped-1080p.mp4`, with the video resolution capped at 1080p. This option produces an `audio.m4a` file for an audio-only asset. * The `audio-only` option produces a single M4A file, called `audio.m4a` for a video or an audio-only asset. MP4 generation will error when this option is specified for a video-only asset. * The `audio-only,capped-1080p` option produces both the `audio.m4a` and `capped-1080p.mp4` files. Only the `capped-1080p.mp4` file is produced for a video-only asset, while only the `audio.m4a` file is produced for an audio-only asset. The `standard`(deprecated) option produces up to three MP4 files with different levels of resolution (`high.mp4`, `medium.mp4`, `low.mp4`, or `audio.m4a` for an audio-only asset). MP4 files are not produced for `none` (default). In most cases you should use our default HLS-based streaming playback (`{playback_id}.m3u8`) which can automatically adjust to viewers' connection speeds, but an mp4 can be useful for some legacy devices or downloading for offline playback. See the [Download your videos guide](https://docs.mux.com/guides/enable-static-mp4-renditions) for more information.
@@ -53,6 +59,8 @@ module MuxRuby
53
59
  # An array of static renditions to create for this asset. You may not enable both `static_renditions` and `mp4_support (the latter being deprecated)`
54
60
  attr_accessor :static_renditions
55
61
 
62
+ attr_accessor :meta
63
+
56
64
  class EnumAttributeValidator
57
65
  attr_reader :datatype
58
66
  attr_reader :allowable_values
@@ -79,7 +87,9 @@ module MuxRuby
79
87
  def self.attribute_map
80
88
  {
81
89
  :'input' => :'input',
90
+ :'inputs' => :'inputs',
82
91
  :'playback_policy' => :'playback_policy',
92
+ :'playback_policies' => :'playback_policies',
83
93
  :'advanced_playback_policies' => :'advanced_playback_policies',
84
94
  :'per_title_encode' => :'per_title_encode',
85
95
  :'passthrough' => :'passthrough',
@@ -90,7 +100,8 @@ module MuxRuby
90
100
  :'max_resolution_tier' => :'max_resolution_tier',
91
101
  :'encoding_tier' => :'encoding_tier',
92
102
  :'video_quality' => :'video_quality',
93
- :'static_renditions' => :'static_renditions'
103
+ :'static_renditions' => :'static_renditions',
104
+ :'meta' => :'meta'
94
105
  }
95
106
  end
96
107
 
@@ -103,7 +114,9 @@ module MuxRuby
103
114
  def self.openapi_types
104
115
  {
105
116
  :'input' => :'Array<InputSettings>',
117
+ :'inputs' => :'Array<InputSettings>',
106
118
  :'playback_policy' => :'Array<PlaybackPolicy>',
119
+ :'playback_policies' => :'Array<PlaybackPolicy>',
107
120
  :'advanced_playback_policies' => :'Array<CreatePlaybackIDRequest>',
108
121
  :'per_title_encode' => :'Boolean',
109
122
  :'passthrough' => :'String',
@@ -114,7 +127,8 @@ module MuxRuby
114
127
  :'max_resolution_tier' => :'String',
115
128
  :'encoding_tier' => :'String',
116
129
  :'video_quality' => :'String',
117
- :'static_renditions' => :'Array<CreateStaticRenditionRequest>'
130
+ :'static_renditions' => :'Array<CreateStaticRenditionRequest>',
131
+ :'meta' => :'AssetMetadata'
118
132
  }
119
133
  end
120
134
 
@@ -145,12 +159,24 @@ module MuxRuby
145
159
  end
146
160
  end
147
161
 
162
+ if attributes.key?(:'inputs')
163
+ if (value = attributes[:'inputs']).is_a?(Array)
164
+ self.inputs = value
165
+ end
166
+ end
167
+
148
168
  if attributes.key?(:'playback_policy')
149
169
  if (value = attributes[:'playback_policy']).is_a?(Array)
150
170
  self.playback_policy = value
151
171
  end
152
172
  end
153
173
 
174
+ if attributes.key?(:'playback_policies')
175
+ if (value = attributes[:'playback_policies']).is_a?(Array)
176
+ self.playback_policies = value
177
+ end
178
+ end
179
+
154
180
  if attributes.key?(:'advanced_playback_policies')
155
181
  if (value = attributes[:'advanced_playback_policies']).is_a?(Array)
156
182
  self.advanced_playback_policies = value
@@ -200,6 +226,10 @@ module MuxRuby
200
226
  self.static_renditions = value
201
227
  end
202
228
  end
229
+
230
+ if attributes.key?(:'meta')
231
+ self.meta = attributes[:'meta']
232
+ end
203
233
  end
204
234
 
205
235
  # Show invalid properties with the reasons. Usually used together with valid?
@@ -281,7 +311,9 @@ module MuxRuby
281
311
  return true if self.equal?(o)
282
312
  self.class == o.class &&
283
313
  input == o.input &&
314
+ inputs == o.inputs &&
284
315
  playback_policy == o.playback_policy &&
316
+ playback_policies == o.playback_policies &&
285
317
  advanced_playback_policies == o.advanced_playback_policies &&
286
318
  per_title_encode == o.per_title_encode &&
287
319
  passthrough == o.passthrough &&
@@ -292,7 +324,8 @@ module MuxRuby
292
324
  max_resolution_tier == o.max_resolution_tier &&
293
325
  encoding_tier == o.encoding_tier &&
294
326
  video_quality == o.video_quality &&
295
- static_renditions == o.static_renditions
327
+ static_renditions == o.static_renditions &&
328
+ meta == o.meta
296
329
  end
297
330
 
298
331
  # @see the `==` method
@@ -304,7 +337,7 @@ module MuxRuby
304
337
  # Calculates hash code according to all attributes.
305
338
  # @return [Integer] Hash code
306
339
  def hash
307
- [input, playback_policy, advanced_playback_policies, per_title_encode, passthrough, mp4_support, normalize_audio, master_access, test, max_resolution_tier, encoding_tier, video_quality, static_renditions].hash
340
+ [input, inputs, playback_policy, playback_policies, advanced_playback_policies, per_title_encode, passthrough, mp4_support, normalize_audio, master_access, test, max_resolution_tier, encoding_tier, video_quality, static_renditions, meta].hash
308
341
  end
309
342
 
310
343
  # Builds the object from hash
@@ -15,9 +15,13 @@ require 'time'
15
15
 
16
16
  module MuxRuby
17
17
  class CreateLiveStreamRequest
18
+ # Deprecated. Use `playback_policies` instead, which accepts an identical type.
18
19
  attr_accessor :playback_policy
19
20
 
20
- # An array of playback policy objects that you want applied to this asset and available through `playback_ids`. `advanced_playback_policies` must be used instead of `playback_policy` when creating a DRM playback ID.
21
+ # An array of playback policy names that you want applied to this live stream and available through `playback_ids`. Options include: * `\"public\"` (anyone with the playback URL can stream the live stream). * `\"signed\"` (an additional access token is required to play the live stream). If no `playback_policies` is set, the live stream will have no playback IDs and will therefore not be playable. For simplicity, a single string name can be used in place of the array in the case of only one playback policy.
22
+ attr_accessor :playback_policies
23
+
24
+ # An array of playback policy objects that you want applied on this live stream and available through `playback_ids`. `advanced_playback_policies` must be used instead of `playback_policies` when creating a DRM playback ID.
21
25
  attr_accessor :advanced_playback_policies
22
26
 
23
27
  attr_accessor :new_asset_settings
@@ -85,6 +89,7 @@ module MuxRuby
85
89
  def self.attribute_map
86
90
  {
87
91
  :'playback_policy' => :'playback_policy',
92
+ :'playback_policies' => :'playback_policies',
88
93
  :'advanced_playback_policies' => :'advanced_playback_policies',
89
94
  :'new_asset_settings' => :'new_asset_settings',
90
95
  :'reconnect_window' => :'reconnect_window',
@@ -112,6 +117,7 @@ module MuxRuby
112
117
  def self.openapi_types
113
118
  {
114
119
  :'playback_policy' => :'Array<PlaybackPolicy>',
120
+ :'playback_policies' => :'Array<PlaybackPolicy>',
115
121
  :'advanced_playback_policies' => :'Array<CreatePlaybackIDRequest>',
116
122
  :'new_asset_settings' => :'CreateAssetRequest',
117
123
  :'reconnect_window' => :'Float',
@@ -157,6 +163,12 @@ module MuxRuby
157
163
  end
158
164
  end
159
165
 
166
+ if attributes.key?(:'playback_policies')
167
+ if (value = attributes[:'playback_policies']).is_a?(Array)
168
+ self.playback_policies = value
169
+ end
170
+ end
171
+
160
172
  if attributes.key?(:'advanced_playback_policies')
161
173
  if (value = attributes[:'advanced_playback_policies']).is_a?(Array)
162
174
  self.advanced_playback_policies = value
@@ -311,6 +323,7 @@ module MuxRuby
311
323
  return true if self.equal?(o)
312
324
  self.class == o.class &&
313
325
  playback_policy == o.playback_policy &&
326
+ playback_policies == o.playback_policies &&
314
327
  advanced_playback_policies == o.advanced_playback_policies &&
315
328
  new_asset_settings == o.new_asset_settings &&
316
329
  reconnect_window == o.reconnect_window &&
@@ -337,7 +350,7 @@ module MuxRuby
337
350
  # Calculates hash code according to all attributes.
338
351
  # @return [Integer] Hash code
339
352
  def hash
340
- [playback_policy, advanced_playback_policies, new_asset_settings, reconnect_window, use_slate_for_standard_latency, reconnect_slate_url, passthrough, audio_only, embedded_subtitles, generated_subtitles, reduced_latency, low_latency, latency_mode, test, simulcast_targets, max_continuous_duration].hash
353
+ [playback_policy, playback_policies, advanced_playback_policies, new_asset_settings, reconnect_window, use_slate_for_standard_latency, reconnect_slate_url, passthrough, audio_only, embedded_subtitles, generated_subtitles, reduced_latency, low_latency, latency_mode, test, simulcast_targets, max_continuous_duration].hash
341
354
  end
342
355
 
343
356
  # Builds the object from hash
@@ -15,13 +15,16 @@ require 'time'
15
15
 
16
16
  module MuxRuby
17
17
  class UpdateAssetRequest
18
- # Arbitrary metadata set for the Asset. Max 255 characters. In order to clear this value, the field should be included with an empty string value.
18
+ # You can set this field to anything you want. It will be included in the asset details and related webhooks. If you're looking for more structured metadata, such as `title` or `external_id` , you can use the `meta` object instead. **Max: 255 characters**. In order to clear this value, the field should be included with an empty string value.
19
19
  attr_accessor :passthrough
20
20
 
21
+ attr_accessor :meta
22
+
21
23
  # Attribute mapping from ruby-style variable name to JSON key.
22
24
  def self.attribute_map
23
25
  {
24
- :'passthrough' => :'passthrough'
26
+ :'passthrough' => :'passthrough',
27
+ :'meta' => :'meta'
25
28
  }
26
29
  end
27
30
 
@@ -33,7 +36,8 @@ module MuxRuby
33
36
  # Attribute type mapping.
34
37
  def self.openapi_types
35
38
  {
36
- :'passthrough' => :'String'
39
+ :'passthrough' => :'String',
40
+ :'meta' => :'AssetMetadata'
37
41
  }
38
42
  end
39
43
 
@@ -61,6 +65,10 @@ module MuxRuby
61
65
  if attributes.key?(:'passthrough')
62
66
  self.passthrough = attributes[:'passthrough']
63
67
  end
68
+
69
+ if attributes.key?(:'meta')
70
+ self.meta = attributes[:'meta']
71
+ end
64
72
  end
65
73
 
66
74
  # Show invalid properties with the reasons. Usually used together with valid?
@@ -81,7 +89,8 @@ module MuxRuby
81
89
  def ==(o)
82
90
  return true if self.equal?(o)
83
91
  self.class == o.class &&
84
- passthrough == o.passthrough
92
+ passthrough == o.passthrough &&
93
+ meta == o.meta
85
94
  end
86
95
 
87
96
  # @see the `==` method
@@ -93,7 +102,7 @@ module MuxRuby
93
102
  # Calculates hash code according to all attributes.
94
103
  # @return [Integer] Hash code
95
104
  def hash
96
- [passthrough].hash
105
+ [passthrough, meta].hash
97
106
  end
98
107
 
99
108
  # Builds the object from hash
@@ -25,6 +25,8 @@ module MuxRuby
25
25
  # The video quality controls the cost, quality, and available platform features for the asset. [See the video quality guide for more details.](https://docs.mux.com/guides/use-video-quality-levels)
26
26
  attr_accessor :video_quality
27
27
 
28
+ attr_accessor :meta
29
+
28
30
  class EnumAttributeValidator
29
31
  attr_reader :datatype
30
32
  attr_reader :allowable_values
@@ -52,7 +54,8 @@ module MuxRuby
52
54
  {
53
55
  :'mp4_support' => :'mp4_support',
54
56
  :'master_access' => :'master_access',
55
- :'video_quality' => :'video_quality'
57
+ :'video_quality' => :'video_quality',
58
+ :'meta' => :'meta'
56
59
  }
57
60
  end
58
61
 
@@ -66,7 +69,8 @@ module MuxRuby
66
69
  {
67
70
  :'mp4_support' => :'String',
68
71
  :'master_access' => :'String',
69
- :'video_quality' => :'String'
72
+ :'video_quality' => :'String',
73
+ :'meta' => :'AssetMetadata'
70
74
  }
71
75
  end
72
76
 
@@ -102,6 +106,10 @@ module MuxRuby
102
106
  if attributes.key?(:'video_quality')
103
107
  self.video_quality = attributes[:'video_quality']
104
108
  end
109
+
110
+ if attributes.key?(:'meta')
111
+ self.meta = attributes[:'meta']
112
+ end
105
113
  end
106
114
 
107
115
  # Show invalid properties with the reasons. Usually used together with valid?
@@ -160,7 +168,8 @@ module MuxRuby
160
168
  self.class == o.class &&
161
169
  mp4_support == o.mp4_support &&
162
170
  master_access == o.master_access &&
163
- video_quality == o.video_quality
171
+ video_quality == o.video_quality &&
172
+ meta == o.meta
164
173
  end
165
174
 
166
175
  # @see the `==` method
@@ -172,7 +181,7 @@ module MuxRuby
172
181
  # Calculates hash code according to all attributes.
173
182
  # @return [Integer] Hash code
174
183
  def hash
175
- [mp4_support, master_access, video_quality].hash
184
+ [mp4_support, master_access, video_quality, meta].hash
176
185
  end
177
186
 
178
187
  # Builds the object from hash