awslive-poster 0.1.0 → 0.1.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: cb8226761e5a65a8447580d8032aec2867e9a5d7c8923f1b265a2cb79d268f66
4
- data.tar.gz: 5a17bb4fae92d73a136f92e84e9304860537ab247ef088be03058e00c586e3c2
3
+ metadata.gz: 753564e7fb69e7762afb65b2769c30a63e146286844916c9e93f2a29cde5c32e
4
+ data.tar.gz: 47422fa3163d44c695efd6ace54816fb4686c68f2bb8dd45c6e8ce496d89b4d8
5
5
  SHA512:
6
- metadata.gz: aff7e0a926b6b3895a1ff83c177b97d6974e5da7c3001efc308e49a4e5dc3c4b1778efbdbf1478f02b8b5025bb41d7cbe006bb98f61508fa802df1f4755446de
7
- data.tar.gz: 298328899e85469be49a4043334be00434b89e962968ace6bb5b3a0bcc5f77ae2a1b019692a29cd0ebfd1d6260a15926de22f53ceb8845f75fc44d5179b90d24
6
+ metadata.gz: 94175fc4a89bf329e446b9b279870ec37d0c4a2feb737fb4243ce8841410f57c08727257e69f48173786fb7bfddaaf40ca7b48a4ba4a6944ba6de5120143c4a6
7
+ data.tar.gz: 84af17c7191aac1373b29afdbaee1d49951ebc97546c962e9d67f55a9caf7feb69f2c92a398bb1007569ad66f687fedd35edc0f5ee8485ad107abcd7faf25a3a
@@ -0,0 +1 @@
1
+ require 'awslive-poster/awslive_poster'
@@ -0,0 +1,135 @@
1
+ require 'aws-sdk-medialive'
2
+ require 'aws-sdk-s3'
3
+ require 'uri'
4
+
5
+ module Awslive
6
+ class Poster
7
+
8
+ class InvalidChannelState < StandardError; end
9
+ class NoFrameCaptureOutputGroup < StandardError; end
10
+ class PosterImageDoesNotExist < StandardError; end
11
+ class NoStartTimeInTag < StandardError; end
12
+
13
+ def initialize(channel_id)
14
+ credentials = Aws::SharedCredentials.new
15
+ if credentials.set?
16
+ @medialiveclient = Aws::MediaLive::Client.new(:credentials => credentials)
17
+ @s3 = Aws::S3::Resource.new(:credentials => credentials)
18
+ else
19
+ @medialiveclient = Aws::MediaLive::Client.new
20
+ @s3 = Aws::S3::Resource.new
21
+ end
22
+ @channel_id = channel_id
23
+ end
24
+
25
+ def get_url(channel_info = nil)
26
+ preview_url = nil
27
+ channel_info = @medialiveclient.describe_channel({ :channel_id => "#{@channel_id}" }) if channel_info.nil?
28
+ channel_state = channel_info[:state]
29
+ if channel_state == "RUNNING"
30
+ out_group = get_framecapture_group(channel_info["encoder_settings"])
31
+ raise NoFrameCaptureOutputGroup.new("Framecapture output group should be configured!") if out_group.nil?
32
+ start_time = get_channel_start_time(channel_info)
33
+ raise NoStartTimeInTag.new("channel_start_time should be provisioned in Channel tag!") if start_time.nil?
34
+ dest_id = get_dest_info(out_group)
35
+ url = get_dest_url(dest_id, channel_info)
36
+ uri = URI(url)
37
+ modifier = get_framecapture_modifier(out_group)
38
+ interval = get_framecapture_interval(out_group, channel_info)
39
+ seq_counter = compute_index(start_time, interval)
40
+ suffix = uri.path[1..-1]
41
+ bucket = @s3.bucket("#{uri.host}")
42
+ obj = bucket.object("#{suffix}#{modifier}.#{seq_counter}.jpg")
43
+ if obj.exists?
44
+ preview_url = obj.presigned_url(:get)
45
+ else
46
+ raise PosterImageDoesNotExist.new("Poster Image #{suffix}#{modifier}.#{seq_counter}.jpg Does not exist!")
47
+ end
48
+ else
49
+ raise InvalidChannelState.new("Channel Need to be in running state!, current state is #{channel_state}")
50
+ end
51
+ preview_url
52
+ end
53
+
54
+ def compute_index(start_time, interval)
55
+ channel_start_time = Time.iso8601(start_time).to_i
56
+ current_time = Time.now.utc.to_i
57
+ diff_time = current_time - channel_start_time
58
+ image_index = (diff_time / interval.to_i).to_i
59
+ index = image_index.to_s.rjust(5,'0')
60
+ index
61
+ end
62
+
63
+ def get_channel_start_time(channel_info)
64
+ start_time = channel_info.tags["channel_start_time"]
65
+ start_time
66
+ end
67
+
68
+ def get_framecapture_group(encode_setting)
69
+ out_grp = nil
70
+ outputgroups = encode_setting["output_groups"] rescue nil
71
+ unless outputgroups.nil?
72
+ outputgroups.each do | output |
73
+ if !output["output_group_settings"]["frame_capture_group_settings"].nil?
74
+ out_grp = output
75
+ break if !out_grp.nil?
76
+ end
77
+ end
78
+ end
79
+ out_grp
80
+ end
81
+
82
+ def get_dest_info(out_grp)
83
+ dest = nil
84
+ if !out_grp["output_group_settings"]["frame_capture_group_settings"].nil?
85
+ dest = out_grp["output_group_settings"]["frame_capture_group_settings"]["destination"]["destination_ref_id"] rescue nil
86
+ end
87
+ dest
88
+ end
89
+
90
+ def get_dest_url(dest_info, channel_info)
91
+ url = nil
92
+ if !channel_info["destinations"].nil?
93
+ channel_info["destinations"].each do | dest |
94
+ if dest["id"] == dest_info
95
+ url = dest["settings"][0]["url"]
96
+ break if !url.nil?
97
+ end
98
+ end
99
+ end
100
+ url
101
+ end
102
+
103
+ def get_framecapture_modifier(out_grp)
104
+ modifier = out_grp["outputs"][0]["output_settings"]["frame_capture_output_settings"]["name_modifier"] rescue nil
105
+ modifier
106
+ end
107
+
108
+ def get_framecapture_interval(out_grp, channel_info)
109
+ interval = nil
110
+ video_desc_name = out_grp["outputs"][0]["video_description_name"]
111
+ if !video_desc_name.nil?
112
+ video_desc_info = get_video_description_info(video_desc_name, channel_info)
113
+ if !video_desc_info.nil?
114
+ interval = video_desc_info["codec_settings"]["frame_capture_settings"]["capture_interval"]
115
+ end
116
+ end
117
+ interval
118
+ end
119
+
120
+ def get_video_description_info(desc_name, channel_info)
121
+ video_info = nil
122
+ videos_desc = channel_info["encoder_settings"]["video_descriptions"]
123
+ if !videos_desc.nil?
124
+ videos_desc.each do | description |
125
+ if description["name"] == desc_name
126
+ video_info = description
127
+ break
128
+ end
129
+ end
130
+ end
131
+ video_info
132
+ end
133
+ end
134
+ end
135
+
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: awslive-poster
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.1.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Maheshwaran G
@@ -66,7 +66,7 @@ dependencies:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
68
  version: '1.40'
69
- description: Utility that generates the Poster Image URL for the running medialive
69
+ description: Utility that generates the Poster Image URL for the running AWS medialive
70
70
  channel
71
71
  email:
72
72
  - maheshwarang@ooyala.com
@@ -74,20 +74,8 @@ executables: []
74
74
  extensions: []
75
75
  extra_rdoc_files: []
76
76
  files:
77
- - ".gitignore"
78
- - ".idea/awslive-poster.iml"
79
- - ".idea/checkstyle-idea.xml"
80
- - CODE_OF_CONDUCT.md
81
- - Gemfile
82
- - Gemfile.lock
83
- - LICENSE.txt
84
- - README.md
85
- - Rakefile
86
- - VERSION
87
- - awslive-poster.gemspec
88
- - bin/console
89
- - bin/setup
90
- - lib/awslive_poster.rb
77
+ - lib/awslive-poster.rb
78
+ - lib/awslive-poster/awslive_poster.rb
91
79
  homepage: https://github.com/cloudaffair/awslive-poster
92
80
  licenses:
93
81
  - MIT
@@ -113,5 +101,6 @@ rubyforge_project:
113
101
  rubygems_version: 2.7.3
114
102
  signing_key:
115
103
  specification_version: 4
116
- summary: Utility that generates the Poster Image URL for the running medialive channel
104
+ summary: Utility that generates the Poster Image URL for the running AWS medialive
105
+ channel
117
106
  test_files: []
data/.gitignore DELETED
@@ -1,10 +0,0 @@
1
- /.bundle/
2
- /.yardoc
3
- /_yardoc/
4
- /coverage/
5
- /doc/
6
- /pkg/
7
- /spec/reports/
8
- /tmp/
9
- /.idea
10
-
@@ -1,74 +0,0 @@
1
- # Contributor Covenant Code of Conduct
2
-
3
- ## Our Pledge
4
-
5
- In the interest of fostering an open and welcoming environment, we as
6
- contributors and maintainers pledge to making participation in our project and
7
- our community a harassment-free experience for everyone, regardless of age, body
8
- size, disability, ethnicity, gender identity and expression, level of experience,
9
- nationality, personal appearance, race, religion, or sexual identity and
10
- orientation.
11
-
12
- ## Our Standards
13
-
14
- Examples of behavior that contributes to creating a positive environment
15
- include:
16
-
17
- * Using welcoming and inclusive language
18
- * Being respectful of differing viewpoints and experiences
19
- * Gracefully accepting constructive criticism
20
- * Focusing on what is best for the community
21
- * Showing empathy towards other community members
22
-
23
- Examples of unacceptable behavior by participants include:
24
-
25
- * The use of sexualized language or imagery and unwelcome sexual attention or
26
- advances
27
- * Trolling, insulting/derogatory comments, and personal or political attacks
28
- * Public or private harassment
29
- * Publishing others' private information, such as a physical or electronic
30
- address, without explicit permission
31
- * Other conduct which could reasonably be considered inappropriate in a
32
- professional setting
33
-
34
- ## Our Responsibilities
35
-
36
- Project maintainers are responsible for clarifying the standards of acceptable
37
- behavior and are expected to take appropriate and fair corrective action in
38
- response to any instances of unacceptable behavior.
39
-
40
- Project maintainers have the right and responsibility to remove, edit, or
41
- reject comments, commits, code, wiki edits, issues, and other contributions
42
- that are not aligned to this Code of Conduct, or to ban temporarily or
43
- permanently any contributor for other behaviors that they deem inappropriate,
44
- threatening, offensive, or harmful.
45
-
46
- ## Scope
47
-
48
- This Code of Conduct applies both within project spaces and in public spaces
49
- when an individual is representing the project or its community. Examples of
50
- representing a project or community include using an official project e-mail
51
- address, posting via an official social media account, or acting as an appointed
52
- representative at an online or offline event. Representation of a project may be
53
- further defined and clarified by project maintainers.
54
-
55
- ## Enforcement
56
-
57
- Instances of abusive, harassing, or otherwise unacceptable behavior may be
58
- reported by contacting the project team at maheshwarang@ooyala.com. All
59
- complaints will be reviewed and investigated and will result in a response that
60
- is deemed necessary and appropriate to the circumstances. The project team is
61
- obligated to maintain confidentiality with regard to the reporter of an incident.
62
- Further details of specific enforcement policies may be posted separately.
63
-
64
- Project maintainers who do not follow or enforce the Code of Conduct in good
65
- faith may face temporary or permanent repercussions as determined by other
66
- members of the project's leadership.
67
-
68
- ## Attribution
69
-
70
- This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71
- available at [http://contributor-covenant.org/version/1/4][version]
72
-
73
- [homepage]: http://contributor-covenant.org
74
- [version]: http://contributor-covenant.org/version/1/4/
data/Gemfile DELETED
@@ -1,4 +0,0 @@
1
- source "https://rubygems.org"
2
-
3
- # Specify your gem's dependencies in awslive-poster.gemspec
4
- gemspec
@@ -1,42 +0,0 @@
1
- PATH
2
- remote: .
3
- specs:
4
- awslive-poster (0.1.0)
5
- aws-sdk-medialive (~> 1.40)
6
- aws-sdk-s3 (~> 1.40)
7
-
8
- GEM
9
- remote: https://rubygems.org/
10
- specs:
11
- aws-eventstream (1.0.3)
12
- aws-partitions (1.266.0)
13
- aws-sdk-core (3.89.1)
14
- aws-eventstream (~> 1.0, >= 1.0.2)
15
- aws-partitions (~> 1, >= 1.239.0)
16
- aws-sigv4 (~> 1.1)
17
- jmespath (~> 1.0)
18
- aws-sdk-kms (1.27.0)
19
- aws-sdk-core (~> 3, >= 3.71.0)
20
- aws-sigv4 (~> 1.1)
21
- aws-sdk-medialive (1.40.0)
22
- aws-sdk-core (~> 3, >= 3.71.0)
23
- aws-sigv4 (~> 1.1)
24
- aws-sdk-s3 (1.60.1)
25
- aws-sdk-core (~> 3, >= 3.83.0)
26
- aws-sdk-kms (~> 1)
27
- aws-sigv4 (~> 1.1)
28
- aws-sigv4 (1.1.0)
29
- aws-eventstream (~> 1.0, >= 1.0.2)
30
- jmespath (1.4.0)
31
- rake (10.4.2)
32
-
33
- PLATFORMS
34
- ruby
35
-
36
- DEPENDENCIES
37
- awslive-poster!
38
- bundler (~> 2.0)
39
- rake (~> 10.0)
40
-
41
- BUNDLED WITH
42
- 2.0.2
@@ -1,21 +0,0 @@
1
- The MIT License (MIT)
2
-
3
- Copyright (c) 2020 Maheshwaran G
4
-
5
- Permission is hereby granted, free of charge, to any person obtaining a copy
6
- of this software and associated documentation files (the "Software"), to deal
7
- in the Software without restriction, including without limitation the rights
8
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- copies of the Software, and to permit persons to whom the Software is
10
- furnished to do so, subject to the following conditions:
11
-
12
- The above copyright notice and this permission notice shall be included in
13
- all copies or substantial portions of the Software.
14
-
15
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
- THE SOFTWARE.
data/README.md DELETED
@@ -1,43 +0,0 @@
1
- # Awslive::Poster
2
-
3
- Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/awslive/poster`. To experiment with that code, run `bin/console` for an interactive prompt.
4
-
5
- TODO: Delete this and the text above, and describe your gem
6
-
7
- ## Installation
8
-
9
- Add this line to your application's Gemfile:
10
-
11
- ```ruby
12
- gem 'awslive-poster'
13
- ```
14
-
15
- And then execute:
16
-
17
- $ bundle
18
-
19
- Or install it yourself as:
20
-
21
- $ gem install awslive-poster
22
-
23
- ## Usage
24
-
25
- TODO: Write usage instructions here
26
-
27
- ## Development
28
-
29
- After checking out the repo, run `bin/setup` to install dependencies. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
-
31
- To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
-
33
- ## Contributing
34
-
35
- Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/awslive-poster. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
36
-
37
- ## License
38
-
39
- The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
40
-
41
- ## Code of Conduct
42
-
43
- Everyone interacting in the Awslive::Poster project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/[USERNAME]/awslive-poster/blob/master/CODE_OF_CONDUCT.md).
data/Rakefile DELETED
@@ -1,2 +0,0 @@
1
- require "bundler/gem_tasks"
2
- task :default => :spec
data/VERSION DELETED
@@ -1 +0,0 @@
1
- 0.1.0
@@ -1,32 +0,0 @@
1
- lib = File.expand_path("lib", __dir__)
2
- $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
-
4
- Gem::Specification.new do |spec|
5
- spec.name = "awslive-poster"
6
- spec.version = File.read(File.expand_path('../VERSION',__FILE__)).strip
7
- spec.authors = ["Maheshwaran G"]
8
- spec.email = ["maheshwarang@ooyala.com"]
9
-
10
- spec.summary = "Utility that generates the Poster Image URL for the running medialive channel"
11
- spec.description = "Utility that generates the Poster Image URL for the running medialive channel"
12
- spec.homepage = "https://github.com/cloudaffair/awslive-poster"
13
- spec.license = "MIT"
14
-
15
-
16
- spec.metadata["homepage_uri"] = spec.homepage
17
- spec.metadata["source_code_uri"] = "https://github.com/cloudaffair/awslive-poster"
18
-
19
- # Specify which files should be added to the gem when it is released.
20
- # The `git ls-files -z` loads the files in the RubyGem that have been added into git.
21
- spec.files = Dir.chdir(File.expand_path('..', __FILE__)) do
22
- `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
23
- end
24
- spec.bindir = "exe"
25
- spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
26
- spec.require_paths = ["lib"]
27
-
28
- spec.add_development_dependency "bundler", "~> 2.0"
29
- spec.add_development_dependency "rake", "~> 10.0"
30
- spec.add_runtime_dependency 'aws-sdk-medialive', '~>1.40'
31
- spec.add_runtime_dependency 'aws-sdk-s3', '~>1.40'
32
- end
@@ -1,14 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require "bundler/setup"
4
- require "awslive/poster"
5
-
6
- # You can add fixtures and/or initialization code here to make experimenting
7
- # with your gem easier. You can also use a different console, if you like.
8
-
9
- # (If you use this, don't forget to add pry to your Gemfile!)
10
- # require "pry"
11
- # Pry.start
12
-
13
- require "irb"
14
- IRB.start(__FILE__)
data/bin/setup DELETED
@@ -1,8 +0,0 @@
1
- #!/usr/bin/env bash
2
- set -euo pipefail
3
- IFS=$'\n\t'
4
- set -vx
5
-
6
- bundle install
7
-
8
- # Do any other automated setup that you need to do here
@@ -1,132 +0,0 @@
1
- require 'aws-sdk-medialive'
2
- require 'aws-sdk-s3'
3
- require 'uri'
4
-
5
- class AwslivePoster
6
-
7
- class InvalidChannelState < StandardError; end
8
- class NoFrameCaptureOutputGroup < StandardError; end
9
- class PosterImageDoesNotExist < StandardError; end
10
- class NoStartTimeInTag < StandardError; end
11
-
12
- def initialize(channel_id)
13
- credentials = Aws::SharedCredentials.new
14
- if credentials.set?
15
- @medialiveclient = Aws::MediaLive::Client.new(:credentials => credentials)
16
- @s3 = Aws::S3::Resource.new(:credentials => credentials)
17
- else
18
- @medialiveclient = Aws::MediaLive::Client.new
19
- @s3 = Aws::S3::Resource.new
20
- end
21
- @channel_id = channel_id
22
- end
23
-
24
- def get_url(channel_info = nil)
25
- preview_url = nil
26
- channel_info = @medialiveclient.describe_channel({ :channel_id => "#{@channel_id}" }) if channel_info.nil?
27
- channel_state = channel_info[:state]
28
- if channel_state == "RUNNING"
29
- out_group = get_framecapture_group(channel_info["encoder_settings"])
30
- raise NoFrameCaptureOutputGroup.new("Framecapture output group should be configured!") if out_group.nil?
31
- start_time = get_channel_start_time(channel_info)
32
- raise NoStartTimeInTag.new("channel_start_time should be provisioned in Channel tag!") if start_time.nil?
33
- dest_id = get_dest_info(out_group)
34
- url = get_dest_url(dest_id, channel_info)
35
- uri = URI(url)
36
- modifier = get_framecapture_modifier(out_group)
37
- interval = get_framecapture_interval(out_group, channel_info)
38
- seq_counter = compute_index(start_time, interval)
39
- suffix = uri.path[1..-1]
40
- bucket = @s3.bucket("#{uri.host}")
41
- obj = bucket.object("#{suffix}#{modifier}.#{seq_counter}.jpg")
42
- if obj.exists?
43
- preview_url = obj.presigned_url(:get)
44
- else
45
- raise PosterImageDoesNotExist.new("Poster Image #{suffix}#{modifier}.#{seq_counter}.jpg Does not exist!")
46
- end
47
- else
48
- raise InvalidChannelState.new("Channel Need to be in running state!, current state is #{channel_state}")
49
- end
50
- preview_url
51
- end
52
-
53
- def compute_index(start_time, interval)
54
- channel_start_time = Time.iso8601(start_time).to_i
55
- current_time = Time.now.utc.to_i
56
- diff_time = current_time - channel_start_time
57
- image_index = (diff_time / interval.to_i).to_i
58
- index = image_index.to_s.rjust(5,'0')
59
- index
60
- end
61
-
62
- def get_channel_start_time(channel_info)
63
- start_time = channel_info.tags["channel_start_time"]
64
- start_time
65
- end
66
-
67
- def get_framecapture_group(encode_setting)
68
- out_grp = nil
69
- outputgroups = encode_setting["output_groups"] rescue nil
70
- unless outputgroups.nil?
71
- outputgroups.each do | output |
72
- if !output["output_group_settings"]["frame_capture_group_settings"].nil?
73
- out_grp = output
74
- break if !out_grp.nil?
75
- end
76
- end
77
- end
78
- out_grp
79
- end
80
-
81
- def get_dest_info(out_grp)
82
- dest = nil
83
- if !out_grp["output_group_settings"]["frame_capture_group_settings"].nil?
84
- dest = out_grp["output_group_settings"]["frame_capture_group_settings"]["destination"]["destination_ref_id"] rescue nil
85
- end
86
- dest
87
- end
88
-
89
- def get_dest_url(dest_info, channel_info)
90
- url = nil
91
- if !channel_info["destinations"].nil?
92
- channel_info["destinations"].each do | dest |
93
- if dest["id"] == dest_info
94
- url = dest["settings"][0]["url"]
95
- break if !url.nil?
96
- end
97
- end
98
- end
99
- url
100
- end
101
-
102
- def get_framecapture_modifier(out_grp)
103
- modifier = out_grp["outputs"][0]["output_settings"]["frame_capture_output_settings"]["name_modifier"] rescue nil
104
- modifier
105
- end
106
-
107
- def get_framecapture_interval(out_grp, channel_info)
108
- interval = nil
109
- video_desc_name = out_grp["outputs"][0]["video_description_name"]
110
- if !video_desc_name.nil?
111
- video_desc_info = get_video_description_info(video_desc_name, channel_info)
112
- if !video_desc_info.nil?
113
- interval = video_desc_info["codec_settings"]["frame_capture_settings"]["capture_interval"]
114
- end
115
- end
116
- interval
117
- end
118
-
119
- def get_video_description_info(desc_name, channel_info)
120
- video_info = nil
121
- videos_desc = channel_info["encoder_settings"]["video_descriptions"]
122
- if !videos_desc.nil?
123
- videos_desc.each do | description |
124
- if description["name"] == desc_name
125
- video_info = description
126
- break
127
- end
128
- end
129
- end
130
- video_info
131
- end
132
- end