wsc_sdk 1.3.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.circleci/config.yml +146 -0
- data/.circleci/docker/build/Dockerfile +3 -0
- data/.circleci/helpers/add_preamble.rb +29 -0
- data/.circleci/helpers/build_docs.sh +5 -0
- data/.circleci/helpers/build_gem.sh +5 -0
- data/.circleci/helpers/debundle-context.sh +14 -0
- data/.circleci/helpers/finalize_release.sh +24 -0
- data/.circleci/helpers/publish_docs.sh +10 -0
- data/.circleci/helpers/release_gem.sh +8 -0
- data/.circleci/helpers/setup.sh +11 -0
- data/.circleci/helpers/setup_aws.sh +13 -0
- data/.circleci/helpers/setup_gem.sh +2 -0
- data/.circleci/helpers/setup_git.sh +27 -0
- data/.circleci/helpers/setup_rubygems.sh +15 -0
- data/.circleci/helpers/test_integration.sh +12 -0
- data/.circleci/helpers/test_unit.sh +6 -0
- data/.circleci/jobs/publish-production.sh +17 -0
- data/.circleci/jobs/publish-staging.sh +17 -0
- data/.circleci/jobs/release-production.sh +21 -0
- data/.circleci/jobs/test-integration.sh +9 -0
- data/.circleci/jobs/test-unit.sh +9 -0
- data/.circleci/tag_repo.rb +46 -0
- data/.gitignore +28 -0
- data/.rspec +2 -0
- data/.yard/config +2 -0
- data/.yard/template/default/fulldoc/html/css/custom.css +151 -0
- data/.yard/template/default/layout/html/footer.erb +0 -0
- data/.yard/template/default/layout/html/headers.erb +10 -0
- data/.yard/template/default/layout/html/layout.erb +45 -0
- data/.yard/template/default/layout/html/setup.rb +24 -0
- data/.yardopts +1 -0
- data/CODE_OF_CONDUCT.md +74 -0
- data/Gemfile +6 -0
- data/Gemfile.lock +99 -0
- data/LICENSE.txt +28 -0
- data/README.md +397 -0
- data/Rakefile +2 -0
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/doc/Hash.html +291 -0
- data/doc/WscSdk.html +570 -0
- data/doc/WscSdk/ApiResponse.html +242 -0
- data/doc/WscSdk/Attributes.html +128 -0
- data/doc/WscSdk/Attributes/Mode.html +191 -0
- data/doc/WscSdk/Attributes/Type.html +389 -0
- data/doc/WscSdk/Client.html +2677 -0
- data/doc/WscSdk/Configuration.html +595 -0
- data/doc/WscSdk/Endpoint.html +2974 -0
- data/doc/WscSdk/Endpoints.html +141 -0
- data/doc/WscSdk/Endpoints/CustomStreamTargets.html +383 -0
- data/doc/WscSdk/Endpoints/LiveStreams.html +197 -0
- data/doc/WscSdk/Endpoints/OutputStreamTargets.html +180 -0
- data/doc/WscSdk/Endpoints/Outputs.html +180 -0
- data/doc/WscSdk/Endpoints/StreamTargets.html +446 -0
- data/doc/WscSdk/Endpoints/Transcoders.html +197 -0
- data/doc/WscSdk/Endpoints/UllStreamTargets.html +383 -0
- data/doc/WscSdk/Endpoints/WowzaStreamTargets.html +383 -0
- data/doc/WscSdk/Enum.html +225 -0
- data/doc/WscSdk/Enums.html +321 -0
- data/doc/WscSdk/Enums/BillingMode.html +188 -0
- data/doc/WscSdk/Enums/BroadcastLocation.html +396 -0
- data/doc/WscSdk/Enums/BufferSize.html +301 -0
- data/doc/WscSdk/Enums/ClosedCaptionType.html +221 -0
- data/doc/WscSdk/Enums/CustomProvider.html +252 -0
- data/doc/WscSdk/Enums/DeliveryMethod.html +188 -0
- data/doc/WscSdk/Enums/DeliveryType.html +188 -0
- data/doc/WscSdk/Enums/Encoder.html +460 -0
- data/doc/WscSdk/Enums/Errors.html +555 -0
- data/doc/WscSdk/Enums/IdleTimeout.html +398 -0
- data/doc/WscSdk/Enums/ImagePosition.html +220 -0
- data/doc/WscSdk/Enums/ModelMode.html +175 -0
- data/doc/WscSdk/Enums/ModelType.html +373 -0
- data/doc/WscSdk/Enums/PlayerType.html +188 -0
- data/doc/WscSdk/Enums/Protocol.html +204 -0
- data/doc/WscSdk/Enums/TargetDeliveryProtocol.html +188 -0
- data/doc/WscSdk/Enums/TranscoderType.html +188 -0
- data/doc/WscSdk/Enums/UserRegion.html +383 -0
- data/doc/WscSdk/Enums/WowzaProvider.html +188 -0
- data/doc/WscSdk/Errors.html +683 -0
- data/doc/WscSdk/Loggable.html +346 -0
- data/doc/WscSdk/Model.html +3316 -0
- data/doc/WscSdk/ModelList.html +442 -0
- data/doc/WscSdk/ModelTemplate.html +267 -0
- data/doc/WscSdk/Models.html +141 -0
- data/doc/WscSdk/Models/CustomStreamTarget.html +192 -0
- data/doc/WscSdk/Models/Error.html +351 -0
- data/doc/WscSdk/Models/LiveStream.html +601 -0
- data/doc/WscSdk/Models/LiveStreamConnectionCode.html +192 -0
- data/doc/WscSdk/Models/LiveStreamState.html +200 -0
- data/doc/WscSdk/Models/LiveStreamStats.html +200 -0
- data/doc/WscSdk/Models/LiveStreamThumbnailUrl.html +200 -0
- data/doc/WscSdk/Models/Output.html +294 -0
- data/doc/WscSdk/Models/OutputStreamTarget.html +274 -0
- data/doc/WscSdk/Models/StreamTarget.html +273 -0
- data/doc/WscSdk/Models/Transcoder.html +793 -0
- data/doc/WscSdk/Models/TranscoderBooleanStat.html +278 -0
- data/doc/WscSdk/Models/TranscoderConnectionCode.html +192 -0
- data/doc/WscSdk/Models/TranscoderFloatStat.html +278 -0
- data/doc/WscSdk/Models/TranscoderIntegerStat.html +278 -0
- data/doc/WscSdk/Models/TranscoderState.html +196 -0
- data/doc/WscSdk/Models/TranscoderStats.html +196 -0
- data/doc/WscSdk/Models/TranscoderStreamTargetState.html +192 -0
- data/doc/WscSdk/Models/TranscoderStringStat.html +278 -0
- data/doc/WscSdk/Models/TranscoderThumbnailUrl.html +196 -0
- data/doc/WscSdk/Models/UllStreamTarget.html +360 -0
- data/doc/WscSdk/Models/WowzaStreamTarget.html +380 -0
- data/doc/WscSdk/Pagination.html +1277 -0
- data/doc/WscSdk/Schema.html +861 -0
- data/doc/WscSdk/SchemaAttribute.html +2400 -0
- data/doc/WscSdk/Templates.html +141 -0
- data/doc/WscSdk/Templates/CustomStreamTarget.html +1045 -0
- data/doc/WscSdk/Templates/LiveStream.html +1432 -0
- data/doc/WscSdk/Templates/Output.html +829 -0
- data/doc/WscSdk/Templates/Transcoder.html +699 -0
- data/doc/WscSdk/Templates/UllStreamTarget.html +411 -0
- data/doc/WscSdk/Templates/WowzaStreamTarget.html +447 -0
- data/doc/WscSdk/TranscoderSharedMethods.html +1113 -0
- data/doc/_index.html +705 -0
- data/doc/class_list.html +51 -0
- data/doc/css/bootstrap.css +5 -0
- data/doc/css/common.css +1 -0
- data/doc/css/custom.css +151 -0
- data/doc/css/full_list.css +58 -0
- data/doc/css/style.css +496 -0
- data/doc/file.README.html +570 -0
- data/doc/file_list.html +56 -0
- data/doc/frames.html +17 -0
- data/doc/images/wsc-ruby-1800x400.png +0 -0
- data/doc/index.html +570 -0
- data/doc/js/app.js +292 -0
- data/doc/js/full_list.js +216 -0
- data/doc/js/jquery.js +4 -0
- data/doc/method_list.html +1731 -0
- data/doc/top-level-namespace.html +182 -0
- data/examples/client.rb +40 -0
- data/examples/helpers.rb +100 -0
- data/examples/live_streams/create.rb +39 -0
- data/examples/live_streams/delete.rb +32 -0
- data/examples/live_streams/find.rb +22 -0
- data/examples/live_streams/flood.rb +126 -0
- data/examples/live_streams/list.rb +24 -0
- data/examples/live_streams/regenerate_connection_code.rb +29 -0
- data/examples/live_streams/reset.rb +32 -0
- data/examples/live_streams/reset_and_wait.rb +51 -0
- data/examples/live_streams/start.rb +33 -0
- data/examples/live_streams/start_and_wait.rb +51 -0
- data/examples/live_streams/state.rb +33 -0
- data/examples/live_streams/stats.rb +43 -0
- data/examples/live_streams/stop.rb +33 -0
- data/examples/live_streams/stop_and_wait.rb +51 -0
- data/examples/live_streams/thumbnail_url.rb +46 -0
- data/examples/live_streams/update.rb +43 -0
- data/examples/live_streams/workflow.rb +165 -0
- data/examples/output_stream_targets/create.rb +56 -0
- data/examples/output_stream_targets/delete.rb +45 -0
- data/examples/output_stream_targets/find.rb +37 -0
- data/examples/output_stream_targets/list.rb +36 -0
- data/examples/output_stream_targets/update.rb +56 -0
- data/examples/outputs/create.rb +49 -0
- data/examples/outputs/delete.rb +39 -0
- data/examples/outputs/find.rb +31 -0
- data/examples/outputs/list.rb +29 -0
- data/examples/outputs/update.rb +50 -0
- data/examples/stream_targets/custom/create.rb +42 -0
- data/examples/stream_targets/custom/delete.rb +31 -0
- data/examples/stream_targets/custom/find.rb +23 -0
- data/examples/stream_targets/custom/list.rb +24 -0
- data/examples/stream_targets/custom/update.rb +43 -0
- data/examples/stream_targets/list.rb +24 -0
- data/examples/stream_targets/ull/create.rb +41 -0
- data/examples/stream_targets/ull/delete.rb +31 -0
- data/examples/stream_targets/ull/find.rb +23 -0
- data/examples/stream_targets/ull/list.rb +24 -0
- data/examples/stream_targets/ull/update.rb +43 -0
- data/examples/stream_targets/wowza/create.rb +42 -0
- data/examples/stream_targets/wowza/delete.rb +31 -0
- data/examples/stream_targets/wowza/find.rb +23 -0
- data/examples/stream_targets/wowza/list.rb +23 -0
- data/examples/stream_targets/wowza/update.rb +43 -0
- data/examples/transcoders/create.rb +39 -0
- data/examples/transcoders/delete.rb +31 -0
- data/examples/transcoders/find.rb +23 -0
- data/examples/transcoders/list.rb +24 -0
- data/examples/transcoders/reset.rb +32 -0
- data/examples/transcoders/reset_and_wait.rb +48 -0
- data/examples/transcoders/start.rb +33 -0
- data/examples/transcoders/start_and_wait.rb +50 -0
- data/examples/transcoders/state.rb +33 -0
- data/examples/transcoders/stats.rb +43 -0
- data/examples/transcoders/stop.rb +33 -0
- data/examples/transcoders/stop_and_wait.rb +50 -0
- data/examples/transcoders/thumbnail_url.rb +46 -0
- data/examples/transcoders/update.rb +43 -0
- data/images/wsc-ruby-1800x400.png +0 -0
- data/lib/wsc_sdk.rb +81 -0
- data/lib/wsc_sdk/client.rb +417 -0
- data/lib/wsc_sdk/configuration.rb +21 -0
- data/lib/wsc_sdk/constants.rb +29 -0
- data/lib/wsc_sdk/endpoint.rb +492 -0
- data/lib/wsc_sdk/endpoints/custom_stream_targets.rb +44 -0
- data/lib/wsc_sdk/endpoints/live_streams.rb +34 -0
- data/lib/wsc_sdk/endpoints/output_stream_targets.rb +17 -0
- data/lib/wsc_sdk/endpoints/outputs.rb +17 -0
- data/lib/wsc_sdk/endpoints/stream_targets.rb +45 -0
- data/lib/wsc_sdk/endpoints/transcoders.rb +38 -0
- data/lib/wsc_sdk/endpoints/ull_stream_targets.rb +44 -0
- data/lib/wsc_sdk/endpoints/wowza_stream_targets.rb +44 -0
- data/lib/wsc_sdk/enums.rb +31 -0
- data/lib/wsc_sdk/enums/billing_mode.rb +20 -0
- data/lib/wsc_sdk/enums/broadcast_location.rb +58 -0
- data/lib/wsc_sdk/enums/buffer_size.rb +41 -0
- data/lib/wsc_sdk/enums/closed_caption_type.rb +26 -0
- data/lib/wsc_sdk/enums/custom_provider.rb +32 -0
- data/lib/wsc_sdk/enums/delivery_method.rb +20 -0
- data/lib/wsc_sdk/enums/delivery_type.rb +20 -0
- data/lib/wsc_sdk/enums/encoder.rb +71 -0
- data/lib/wsc_sdk/enums/idle_timeout.rb +50 -0
- data/lib/wsc_sdk/enums/image_position.rb +26 -0
- data/lib/wsc_sdk/enums/player_type.rb +20 -0
- data/lib/wsc_sdk/enums/protocol.rb +23 -0
- data/lib/wsc_sdk/enums/target_delivery_protocol.rb +20 -0
- data/lib/wsc_sdk/enums/transcoder_type.rb +20 -0
- data/lib/wsc_sdk/enums/wowza_provider.rb +20 -0
- data/lib/wsc_sdk/errors.rb +115 -0
- data/lib/wsc_sdk/model.rb +515 -0
- data/lib/wsc_sdk/model_list.rb +42 -0
- data/lib/wsc_sdk/model_template.rb +27 -0
- data/lib/wsc_sdk/models/custom_stream_target.rb +34 -0
- data/lib/wsc_sdk/models/error.rb +53 -0
- data/lib/wsc_sdk/models/live_stream.rb +130 -0
- data/lib/wsc_sdk/models/live_stream_connection_code.rb +31 -0
- data/lib/wsc_sdk/models/live_stream_state.rb +20 -0
- data/lib/wsc_sdk/models/live_stream_stats.rb +20 -0
- data/lib/wsc_sdk/models/live_stream_thumbnail_url.rb +20 -0
- data/lib/wsc_sdk/models/output.rb +61 -0
- data/lib/wsc_sdk/models/output_stream_target.rb +37 -0
- data/lib/wsc_sdk/models/stream_target.rb +29 -0
- data/lib/wsc_sdk/models/transcoder.rb +135 -0
- data/lib/wsc_sdk/models/transcoder_boolean_stat.rb +41 -0
- data/lib/wsc_sdk/models/transcoder_connection_code.rb +29 -0
- data/lib/wsc_sdk/models/transcoder_float_stat.rb +40 -0
- data/lib/wsc_sdk/models/transcoder_integer_stat.rb +40 -0
- data/lib/wsc_sdk/models/transcoder_state.rb +31 -0
- data/lib/wsc_sdk/models/transcoder_stats.rb +51 -0
- data/lib/wsc_sdk/models/transcoder_stream_target_state.rb +29 -0
- data/lib/wsc_sdk/models/transcoder_string_stat.rb +40 -0
- data/lib/wsc_sdk/models/transcoder_thumbnail_url.rb +29 -0
- data/lib/wsc_sdk/models/ull_stream_target.rb +54 -0
- data/lib/wsc_sdk/models/wowza_stream_target.rb +60 -0
- data/lib/wsc_sdk/modules/api_response.rb +24 -0
- data/lib/wsc_sdk/modules/loggable.rb +44 -0
- data/lib/wsc_sdk/modules/transcoder_shared_methods.rb +221 -0
- data/lib/wsc_sdk/pagination.rb +89 -0
- data/lib/wsc_sdk/schema.rb +140 -0
- data/lib/wsc_sdk/schema_attribute.rb +349 -0
- data/lib/wsc_sdk/templates/custom_stream_target.rb +154 -0
- data/lib/wsc_sdk/templates/live_stream.rb +234 -0
- data/lib/wsc_sdk/templates/output.rb +133 -0
- data/lib/wsc_sdk/templates/transcoder.rb +97 -0
- data/lib/wsc_sdk/templates/ull_stream_target.rb +49 -0
- data/lib/wsc_sdk/templates/wowza_stream_target.rb +57 -0
- data/lib/wsc_sdk/version.rb +7 -0
- data/wsc_sdk.gemspec +48 -0
- metadata +460 -0
@@ -0,0 +1,24 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present, if not ask for them.
|
9
|
+
arguments = ask_for_arguments(__FILE__, { pagination_page: 1, pagination_per_page: 25 })
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
page = arguments[0] # First argument is the page number (default: 1)
|
14
|
+
per_page = arguments[1] # Second argument is the items per page (default: 25, max: 1000)
|
15
|
+
|
16
|
+
# Request the list of live_streams using pagination
|
17
|
+
list = live_streams.list(pagination: { page: page.to_i, per_page: per_page.to_i })
|
18
|
+
|
19
|
+
# Handle an API error (in the helpers.rb file)
|
20
|
+
handle_api_error(list, "There was an error retrieving the list of live streams") unless list.success?
|
21
|
+
|
22
|
+
# Output the list of live_streams
|
23
|
+
# Defined in helpers.rb
|
24
|
+
output_model_list(list, "Live Streams: #{list.keys.length}", true, :name)
|
@@ -0,0 +1,29 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Regenerate the connection code
|
22
|
+
connection_code = live_stream.regenerate_connection_code
|
23
|
+
|
24
|
+
# Handle an API error (in the helpers.rb file)
|
25
|
+
handle_api_error(connection_code, "There was an error regenerating the connection code") unless connection_code.success?
|
26
|
+
|
27
|
+
# Output the live_stream connection code
|
28
|
+
# Defined in the helpers.rb file.
|
29
|
+
output_model_attributes(connection_code, "Live Stream Connection Code:")
|
@@ -0,0 +1,32 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of resetting the live_stream
|
22
|
+
#
|
23
|
+
# NOTE: You can also reset and wait for the live_stream state to transition to
|
24
|
+
# a reset state. See the `reset_and_wait` example.
|
25
|
+
state = live_stream.reset
|
26
|
+
|
27
|
+
# Handle an API error (in the helpers.rb file)
|
28
|
+
handle_api_error(state, "There was an error resetting the live stream") unless state.success?
|
29
|
+
|
30
|
+
# Output the final state of the live stream
|
31
|
+
# Defined in the helpers.rb file.
|
32
|
+
output_model_attributes(state, "Live Stream State:")
|
@@ -0,0 +1,51 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of resetting the live_stream. We add a code block, which
|
22
|
+
# instructs the SDK to enter a wait loop and periodically polls the API
|
23
|
+
# for the live_stream state until either the `started` state is returned or
|
24
|
+
# the timeout period is reached.
|
25
|
+
state = live_stream.reset do |wait_state, live_stream_state|
|
26
|
+
|
27
|
+
# This code will execute each time the state of the live_stream is polled
|
28
|
+
# during the wait loop. You can check the wait_state to determine what the
|
29
|
+
# outcomes of each request are.
|
30
|
+
|
31
|
+
if wait_state == :waiting
|
32
|
+
# We're still waiting for the started state to be returned
|
33
|
+
puts "Waiting..."
|
34
|
+
elsif wait_state == :complete
|
35
|
+
# We've successfully reset the live_stream, so output the state
|
36
|
+
# Defined in the helpers.rb file.
|
37
|
+
output_model_attributes(live_stream_state, "Completed Live Stream State:")
|
38
|
+
elsif wait_state == :timeout
|
39
|
+
# A timeout occurs if the reset state isn't reached within the timeout
|
40
|
+
# limit, which defaults to 30 seconds.
|
41
|
+
|
42
|
+
puts "TIMEOUT: Could not reset the live_stream within the timeout period."
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
# Handle an API error (in the helpers.rb file)
|
47
|
+
handle_api_error(state, "There was an error starting the live stream") unless state.success?
|
48
|
+
|
49
|
+
# Output the final state of the live stream
|
50
|
+
# Defined in the helpers.rb file.
|
51
|
+
output_model_attributes(state, "Live Stream State:")
|
@@ -0,0 +1,33 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of starting the live_stream
|
22
|
+
#
|
23
|
+
# NOTE: You can also start and wait for the live_stream state to transition to
|
24
|
+
# a started state. See the `start_and_wait` example.
|
25
|
+
#
|
26
|
+
state = live_stream.start
|
27
|
+
|
28
|
+
# Handle an API error (in the helpers.rb file)
|
29
|
+
handle_api_error(state, "There was an error starting the live stream") unless state.success?
|
30
|
+
|
31
|
+
# Output the live_stream state
|
32
|
+
# Defined in helper.rb
|
33
|
+
output_model_attributes(state, "Live Stream State:")
|
@@ -0,0 +1,51 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of starting the live_stream. We add a code block, which
|
22
|
+
# instructs the SDK to enter a wait loop, and periodically polls the API
|
23
|
+
# for the live_stream state until either the `started` state is returned or
|
24
|
+
# the timeout period is reached.
|
25
|
+
state = live_stream.start do |wait_state, live_stream_state|
|
26
|
+
|
27
|
+
# This code will execute each time the state of the live_stream is polled
|
28
|
+
# during the wait loop. You can check the wait_state to determine what the
|
29
|
+
# outcomes of each request are.
|
30
|
+
|
31
|
+
if wait_state == :waiting
|
32
|
+
# We're still waiting for the started state to be returned
|
33
|
+
puts "Waiting..."
|
34
|
+
elsif wait_state == :complete
|
35
|
+
# We've successfully started the live_stream, output the state
|
36
|
+
# Defined in the helpers.rb file.
|
37
|
+
output_model_attributes(live_stream_state, "Completed Live Stream State:")
|
38
|
+
elsif wait_state == :timeout
|
39
|
+
# A timeout occurs if the start state isn't reached within the timeout
|
40
|
+
# limit, which defaults to 30 seconds.
|
41
|
+
|
42
|
+
puts "TIMEOUT: Could not start the live stream within the timeout period."
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
# Handle an API error. (In the helpers.rb file)
|
47
|
+
handle_api_error(state, "There was an error starting the live stream") unless state.success?
|
48
|
+
|
49
|
+
# Output the final state of the live stream.
|
50
|
+
# Defined in the helpers.rb file.
|
51
|
+
output_model_attributes(state, "Live Stream State:")
|
@@ -0,0 +1,33 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of stopping the live_stream
|
22
|
+
#
|
23
|
+
# NOTE: You can also stop and wait for the live_stream state to transition to
|
24
|
+
# a stopped state. See the `stop_and_wait` example.
|
25
|
+
#
|
26
|
+
state = live_stream.state
|
27
|
+
|
28
|
+
# Handle an API error (in the helpers.rb file)
|
29
|
+
handle_api_error(state, "There was an error getting the live stream state") unless state.success?
|
30
|
+
|
31
|
+
# Output the live_stream state
|
32
|
+
# Defined in helpers.rb
|
33
|
+
output_model_attributes(state, "Live Stream State:")
|
@@ -0,0 +1,43 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Request the live_stream state
|
22
|
+
state = live_stream.state
|
23
|
+
|
24
|
+
# Handle an API error (in the helpers.rb file)
|
25
|
+
handle_api_error(state, "There was an error getting the live stream state") unless state.success?
|
26
|
+
|
27
|
+
# Ensure the live_stream is started
|
28
|
+
if state.state != 'started'
|
29
|
+
# Start the live_stream and wait
|
30
|
+
result = live_stream.start do |wait_state, live_stream_state|
|
31
|
+
puts "Waiting for live_stream to start"
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# Request the current statistics from the live_stream
|
36
|
+
stats = live_stream.stats
|
37
|
+
|
38
|
+
# Handle an API error (in the helpers.rb file)
|
39
|
+
handle_api_error(stats, "There was an error getting the live stream stats") unless stats.success?
|
40
|
+
|
41
|
+
# Output the current live_stream statistics
|
42
|
+
# Defined in helper.rb
|
43
|
+
output_model_attributes(stats, "Live Stream Stats:")
|
@@ -0,0 +1,33 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of stopping the live_stream
|
22
|
+
#
|
23
|
+
# NOTE: You can also stop and wait for the live_stream state to transition to
|
24
|
+
# a stopped state. See the `stop_and_wait` example.
|
25
|
+
#
|
26
|
+
state = live_stream.stop
|
27
|
+
|
28
|
+
# Handle an API error (in the helpers.rb file)
|
29
|
+
handle_api_error(state, "There was an error getting the live stream state") unless state.success?
|
30
|
+
|
31
|
+
# Output the live_stream state
|
32
|
+
# Defined in helpers.rb
|
33
|
+
output_model_attributes(state, "Live Stream State:")
|
@@ -0,0 +1,51 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Get the result of stopping the live_stream. We add a code block, which
|
22
|
+
# instructs the SDK to enter a wait loop and periodically polls the API
|
23
|
+
# for the live_stream state until either the `stopped` state is returned or
|
24
|
+
# the timeout period is reached.
|
25
|
+
state = live_stream.stop do |wait_state, live_stream_state|
|
26
|
+
|
27
|
+
# This code will execute each time the state of the live_stream is polled
|
28
|
+
# during the wait loop. You can check the wait_state to determine what the
|
29
|
+
# outcomes of each request are.
|
30
|
+
|
31
|
+
if wait_state == :waiting
|
32
|
+
# We're still waiting for the stopped state to be returned
|
33
|
+
puts "Waiting..."
|
34
|
+
elsif wait_state == :complete
|
35
|
+
# We've successfully stopped the live_stream
|
36
|
+
# Defined in helpers.rb
|
37
|
+
output_model_attributes(live_stream_state, "Completed Live Stream State:")
|
38
|
+
elsif wait_state == :timeout
|
39
|
+
# A timeout occurs if the stop state isn't reached within the timeout
|
40
|
+
# limit, which defaults to 30 seconds.
|
41
|
+
|
42
|
+
puts "TIMEOUT: Could not stop the live stream within the timeout period."
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
# Handle an API error (in the helpers.rb file)
|
47
|
+
handle_api_error(state, "There was an error stopping the live stream") unless state.success?
|
48
|
+
|
49
|
+
# Output the final live_stream state
|
50
|
+
# Defined in helpers.rb
|
51
|
+
output_model_attributes(state, "Final Live Stream State:")
|
@@ -0,0 +1,46 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
|
15
|
+
# Request the live_stream object
|
16
|
+
live_stream = live_streams.find(live_stream_id)
|
17
|
+
|
18
|
+
# Handle an API error (in the helpers.rb file)
|
19
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
20
|
+
|
21
|
+
# Request the live_stream state
|
22
|
+
state = live_stream.state
|
23
|
+
|
24
|
+
# Handle an API error (in the helpers.rb file)
|
25
|
+
handle_api_error(state, "There was an error getting the live stream state") unless state.success?
|
26
|
+
|
27
|
+
# Ensure the live_stream is started
|
28
|
+
if state.state != 'started'
|
29
|
+
# Start the live_stream and wait
|
30
|
+
state = live_stream.start do |wait_state, live_stream_state|
|
31
|
+
puts "Waiting for live_stream to start"
|
32
|
+
end
|
33
|
+
|
34
|
+
# Handle an API error (in the helpers.rb file)
|
35
|
+
handle_api_error(state, "There was an error starting the live stream") unless state.success?
|
36
|
+
end
|
37
|
+
|
38
|
+
# Request the thumbnail url
|
39
|
+
thumbnail = live_stream.thumbnail_url
|
40
|
+
|
41
|
+
# Handle an API error (in the helpers.rb file)
|
42
|
+
handle_api_error(thumbnail, "There was an error getting the live stream thumbnail url") unless thumbnail.success?
|
43
|
+
|
44
|
+
# Output the thumbnail URL
|
45
|
+
# Defined in helpers.rb
|
46
|
+
output_model_attributes(thumbnail, "Live Stream Thumbnail:")
|
@@ -0,0 +1,43 @@
|
|
1
|
+
####> This code and all components © 2015 – 2019 Wowza Media Systems, LLC. All rights reserved.
|
2
|
+
####> This code is licensed pursuant to the BSD 3-Clause License.
|
3
|
+
|
4
|
+
require "wsc_sdk"
|
5
|
+
require_relative "../client" # Get our client
|
6
|
+
require_relative "../helpers" # Include some helpers to make the code more direct
|
7
|
+
|
8
|
+
# Ensure the args passed in are present
|
9
|
+
arguments = ask_for_arguments(__FILE__, live_stream_id: nil, new_live_stream_name: nil)
|
10
|
+
|
11
|
+
# Extract some data into convenience variables
|
12
|
+
live_streams = $client.live_streams
|
13
|
+
live_stream_id = arguments[0]
|
14
|
+
live_stream_name = arguments[1]
|
15
|
+
|
16
|
+
# Request the live_stream object
|
17
|
+
live_stream = live_streams.find(live_stream_id)
|
18
|
+
|
19
|
+
# Handle an API error (in the helpers.rb file)
|
20
|
+
handle_api_error(live_stream, "There was an error finding the live stream") unless live_stream.success?
|
21
|
+
|
22
|
+
# Update the live_stream
|
23
|
+
live_stream.name = live_stream_name
|
24
|
+
|
25
|
+
# If the live_stream is invalid, output the messages and exit
|
26
|
+
unless (live_stream.valid?)
|
27
|
+
puts "Live Stream is invalid:"
|
28
|
+
|
29
|
+
live_stream.errors.each do |field, message|
|
30
|
+
puts " - #{field}: #{message}"
|
31
|
+
end
|
32
|
+
exit
|
33
|
+
end
|
34
|
+
|
35
|
+
# Get the result of saving the object to the API
|
36
|
+
saved = live_stream.save
|
37
|
+
|
38
|
+
# Handle an API error (in the helpers.rb file)
|
39
|
+
handle_api_error(saved, "There was an error saving the live stream") unless saved.success?
|
40
|
+
|
41
|
+
# Output the live_stream details
|
42
|
+
# Defined in helpers.rb
|
43
|
+
output_model_attributes(live_stream, "Live Stream: #{live_stream.name}")
|