mux-rails 0.2.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.
- checksums.yaml +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +95 -0
- data/Rakefile +32 -0
- data/app/controllers/mux/application_controller.rb +5 -0
- data/app/controllers/mux/events_controller.rb +20 -0
- data/config/routes.rb +3 -0
- data/lib/mux/client.rb +31 -0
- data/lib/mux/engine.rb +5 -0
- data/lib/mux/event.rb +12 -0
- data/lib/mux/notifications.rb +27 -0
- data/lib/mux/rails.rb +5 -0
- data/lib/mux/rails/version.rb +5 -0
- metadata +125 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: 9daf9dfa3ace722030cdfa1020cb3682771167ef24cbb91394fa59b6007a3243
|
4
|
+
data.tar.gz: d2f33afce8d1b13649bbee69e38912dc59cbbd82ccae9f7d926178e83b62180f
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: cd03523ecd957b317f4f7cc5cd2ce8cf2e07d3068124347b283f2ed1432cd3aa2b026cfec68621d5c1569431aaf52c6c798c50e0361e6119ecccead2067c3da9
|
7
|
+
data.tar.gz: 6a725b3b197c054f75abc3e7114b243d6058b6d1b395925099d00e7e372b537c3eb9145ff9b7432503812266b28d49707258a989aac87147ba6d5f05c0096ebd
|
data/MIT-LICENSE
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
Copyright 2019 asgerb
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
a copy of this software and associated documentation files (the
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
the following conditions:
|
10
|
+
|
11
|
+
The above copyright notice and this permission notice shall be
|
12
|
+
included in all copies or substantial portions of the Software.
|
13
|
+
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/README.md
ADDED
@@ -0,0 +1,95 @@
|
|
1
|
+
# Mux::Rails
|
2
|
+
|
3
|
+

|
4
|
+
|
5
|
+
A Rails Engine for working with [Mux](https://mux.com/).
|
6
|
+
|
7
|
+
Use `Mux::Client` to create assets and `Mux::Notifications` (built on the
|
8
|
+
`ActiveSupport::Notifications` API) to handle incoming webhook requests.
|
9
|
+
|
10
|
+
## Installation
|
11
|
+
Add this line to your application's Gemfile:
|
12
|
+
|
13
|
+
```ruby
|
14
|
+
gem 'mux-rails'
|
15
|
+
```
|
16
|
+
|
17
|
+
```ruby
|
18
|
+
# config/routes.rb
|
19
|
+
mount Mux::Engine, at: "/mux" # provide a custom path
|
20
|
+
```
|
21
|
+
|
22
|
+
## Usage
|
23
|
+
|
24
|
+
### Setup Mux tokens
|
25
|
+
|
26
|
+
```ruby
|
27
|
+
# config/initializers/mux.rb
|
28
|
+
MuxRuby.configure do |config|
|
29
|
+
config.username = ENV["MUX_TOKEN_ID"]
|
30
|
+
config.password = ENV["MUX_TOKEN_SECRET"]
|
31
|
+
end
|
32
|
+
```
|
33
|
+
|
34
|
+
### Creating assets
|
35
|
+
|
36
|
+
Create a Mux asset by using the `Mux::Client.create_asset(url)` method, passing
|
37
|
+
the url to the video. The method returns a Mux asset id.
|
38
|
+
|
39
|
+
```ruby
|
40
|
+
mux_asset_id = Mux::Client.create_asset("http://foo.com/bar.mp4")
|
41
|
+
# You probably want to store mux_asset_id somewhere for future reference
|
42
|
+
```
|
43
|
+
|
44
|
+
### Deleting assets
|
45
|
+
|
46
|
+
Delete an asset using the `Mux::Client.destroy_asset(asset_id)` method, passing
|
47
|
+
the asset id:
|
48
|
+
|
49
|
+
```ruby
|
50
|
+
Mux::Client.destroy_asset("mux_asset_id")
|
51
|
+
```
|
52
|
+
|
53
|
+
### Fetching asset
|
54
|
+
|
55
|
+
Fetch an asset using the `Mux::Client.get_asset(asset_id)` method, passing
|
56
|
+
the asset id. This returns a
|
57
|
+
[JSON object](https://docs.mux.com/docs/webhooks#section-example-response):
|
58
|
+
|
59
|
+
```ruby
|
60
|
+
asset = Mux::Client.get_asset("mux_asset_id")
|
61
|
+
puts asset.data.status
|
62
|
+
```
|
63
|
+
|
64
|
+
### Handling webhook requests
|
65
|
+
|
66
|
+
Using a subscriber with a block we can listen to incoming events from Mux and do further work:
|
67
|
+
|
68
|
+
```ruby
|
69
|
+
# config/initializers/mux.rb
|
70
|
+
# ...
|
71
|
+
|
72
|
+
Mux::Notifications.subscribe "video.asset.created" do |event|
|
73
|
+
# handle asset created
|
74
|
+
# event.object.id == mux_asset_id
|
75
|
+
# event.data.playback_ids.first.id
|
76
|
+
end
|
77
|
+
|
78
|
+
Mux::Notifications.subscribe "video.asset.ready" do |event|
|
79
|
+
# handle asset ready
|
80
|
+
# event.object.id == mux_asset_id
|
81
|
+
# event.data.playback_ids.first.id
|
82
|
+
end
|
83
|
+
|
84
|
+
Mux::Notifications.subscribe "video.asset.deleted" do |event|
|
85
|
+
# handle asset deleted
|
86
|
+
# event.object.id == mux_asset_id
|
87
|
+
# event.data.playback_ids.first.id
|
88
|
+
end
|
89
|
+
```
|
90
|
+
|
91
|
+
The block is passed an event which is simply the incoming JSON (take a peek
|
92
|
+
in [fixtures](test/fixtures) for examples) wrapped in an OpenStruct for ease of access.
|
93
|
+
|
94
|
+
## License
|
95
|
+
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
|
data/Rakefile
ADDED
@@ -0,0 +1,32 @@
|
|
1
|
+
begin
|
2
|
+
require 'bundler/setup'
|
3
|
+
rescue LoadError
|
4
|
+
puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
|
5
|
+
end
|
6
|
+
|
7
|
+
require 'rdoc/task'
|
8
|
+
|
9
|
+
RDoc::Task.new(:rdoc) do |rdoc|
|
10
|
+
rdoc.rdoc_dir = 'rdoc'
|
11
|
+
rdoc.title = 'Mux::Rails'
|
12
|
+
rdoc.options << '--line-numbers'
|
13
|
+
rdoc.rdoc_files.include('README.md')
|
14
|
+
rdoc.rdoc_files.include('lib/**/*.rb')
|
15
|
+
end
|
16
|
+
|
17
|
+
APP_RAKEFILE = File.expand_path("test/dummy/Rakefile", __dir__)
|
18
|
+
load 'rails/tasks/engine.rake'
|
19
|
+
|
20
|
+
load 'rails/tasks/statistics.rake'
|
21
|
+
|
22
|
+
require 'bundler/gem_tasks'
|
23
|
+
|
24
|
+
require 'rake/testtask'
|
25
|
+
|
26
|
+
Rake::TestTask.new(:test) do |t|
|
27
|
+
t.libs << 'test'
|
28
|
+
t.pattern = 'test/**/*_test.rb'
|
29
|
+
t.verbose = false
|
30
|
+
end
|
31
|
+
|
32
|
+
task default: :test
|
@@ -0,0 +1,20 @@
|
|
1
|
+
module Mux
|
2
|
+
class EventsController < ActionController::Base
|
3
|
+
# QUESTION: Is this the right way to handle it?
|
4
|
+
if ::Rails.application.config.action_controller.default_protect_from_forgery
|
5
|
+
skip_before_action :verify_authenticity_token
|
6
|
+
end
|
7
|
+
|
8
|
+
def create
|
9
|
+
Mux::Notifications.instrument(event)
|
10
|
+
head :ok
|
11
|
+
end
|
12
|
+
|
13
|
+
private
|
14
|
+
|
15
|
+
def event
|
16
|
+
event = JSON.parse(request.body.read, object_class: OpenStruct)
|
17
|
+
Mux::Event.new(event)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
data/config/routes.rb
ADDED
data/lib/mux/client.rb
ADDED
@@ -0,0 +1,31 @@
|
|
1
|
+
require "mux_ruby"
|
2
|
+
|
3
|
+
module Mux
|
4
|
+
class Client
|
5
|
+
class << self
|
6
|
+
def create_asset(url, options = {})
|
7
|
+
playback_policy = options.fetch(:playback_policy, "public")
|
8
|
+
request = MuxRuby::CreateAssetRequest.new
|
9
|
+
request.input = url
|
10
|
+
request.playback_policy = MuxRuby::PlaybackPolicy.build_from_hash(playback_policy)
|
11
|
+
response = assets_api.create_asset(request)
|
12
|
+
return response.data.id
|
13
|
+
end
|
14
|
+
|
15
|
+
def destroy_asset(asset_id, options = {})
|
16
|
+
assets_api.delete_asset(asset_id, options)
|
17
|
+
end
|
18
|
+
|
19
|
+
# TODO: Figure out if and how to wrap the response
|
20
|
+
def get_asset(asset_id, options = {})
|
21
|
+
assets_api.get_asset(asset_id, options)
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def assets_api
|
27
|
+
@assets_api ||= MuxRuby::AssetsApi.new
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
data/lib/mux/engine.rb
ADDED
data/lib/mux/event.rb
ADDED
@@ -0,0 +1,12 @@
|
|
1
|
+
module Mux
|
2
|
+
class Event
|
3
|
+
# QUESTION: Is there security concerns here? This implementation seems very naive ;-)
|
4
|
+
def initialize(payload)
|
5
|
+
@event = OpenStruct.new(payload)
|
6
|
+
end
|
7
|
+
|
8
|
+
def method_missing(method, *args, &block)
|
9
|
+
@event.send(method, *args, &block)
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
require "active_support/notifications"
|
2
|
+
|
3
|
+
module Mux
|
4
|
+
module Notifications
|
5
|
+
class << self
|
6
|
+
def instrument(event)
|
7
|
+
return unless event
|
8
|
+
ActiveSupport::Notifications.instrument "mux.#{event.type}", event
|
9
|
+
end
|
10
|
+
|
11
|
+
def subscribe(name, &block)
|
12
|
+
ActiveSupport::Notifications.subscribe %r{^mux\.#{name}}, SubscriberWrapper.call(block)
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
class SubscriberWrapper < Struct.new(:subscriber)
|
17
|
+
def self.call(subscriber)
|
18
|
+
new(subscriber)
|
19
|
+
end
|
20
|
+
|
21
|
+
def call(*args)
|
22
|
+
payload = args.last
|
23
|
+
subscriber.call(payload)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
data/lib/mux/rails.rb
ADDED
metadata
ADDED
@@ -0,0 +1,125 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: mux-rails
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.2.0
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Asger Behncke Jacobsen
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2021-03-19 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: rails
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - ">="
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: '5.0'
|
20
|
+
type: :runtime
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - ">="
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: '5.0'
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: mux_ruby
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - "~>"
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: 1.8.0
|
34
|
+
type: :runtime
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - "~>"
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: 1.8.0
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: minitest
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - "~>"
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '5.0'
|
48
|
+
type: :development
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - "~>"
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '5.0'
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: minitest-rails
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - ">="
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '0'
|
62
|
+
type: :development
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ">="
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0'
|
69
|
+
- !ruby/object:Gem::Dependency
|
70
|
+
name: sqlite3
|
71
|
+
requirement: !ruby/object:Gem::Requirement
|
72
|
+
requirements:
|
73
|
+
- - ">="
|
74
|
+
- !ruby/object:Gem::Version
|
75
|
+
version: '0'
|
76
|
+
type: :development
|
77
|
+
prerelease: false
|
78
|
+
version_requirements: !ruby/object:Gem::Requirement
|
79
|
+
requirements:
|
80
|
+
- - ">="
|
81
|
+
- !ruby/object:Gem::Version
|
82
|
+
version: '0'
|
83
|
+
description: A Rails Engine for integrating with Mux.
|
84
|
+
email:
|
85
|
+
- a@asgerbehnckejacobsen.dk
|
86
|
+
executables: []
|
87
|
+
extensions: []
|
88
|
+
extra_rdoc_files: []
|
89
|
+
files:
|
90
|
+
- MIT-LICENSE
|
91
|
+
- README.md
|
92
|
+
- Rakefile
|
93
|
+
- app/controllers/mux/application_controller.rb
|
94
|
+
- app/controllers/mux/events_controller.rb
|
95
|
+
- config/routes.rb
|
96
|
+
- lib/mux/client.rb
|
97
|
+
- lib/mux/engine.rb
|
98
|
+
- lib/mux/event.rb
|
99
|
+
- lib/mux/notifications.rb
|
100
|
+
- lib/mux/rails.rb
|
101
|
+
- lib/mux/rails/version.rb
|
102
|
+
homepage: https://www.github.com/asgerb/mux-rails
|
103
|
+
licenses:
|
104
|
+
- MIT
|
105
|
+
metadata: {}
|
106
|
+
post_install_message:
|
107
|
+
rdoc_options: []
|
108
|
+
require_paths:
|
109
|
+
- lib
|
110
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
111
|
+
requirements:
|
112
|
+
- - ">="
|
113
|
+
- !ruby/object:Gem::Version
|
114
|
+
version: '0'
|
115
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
116
|
+
requirements:
|
117
|
+
- - ">="
|
118
|
+
- !ruby/object:Gem::Version
|
119
|
+
version: '0'
|
120
|
+
requirements: []
|
121
|
+
rubygems_version: 3.1.2
|
122
|
+
signing_key:
|
123
|
+
specification_version: 4
|
124
|
+
summary: A Rails Engine for integrating with Mux.
|
125
|
+
test_files: []
|