stupeflix 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/.gitignore ADDED
@@ -0,0 +1,18 @@
1
+ *.gem
2
+ *.rbc
3
+ .idea/
4
+ .bundle
5
+ .config
6
+ .yardoc
7
+ Gemfile.lock
8
+ InstalledFiles
9
+ _yardoc
10
+ coverage
11
+ doc/
12
+ lib/bundler/man
13
+ pkg
14
+ rdoc
15
+ spec/reports
16
+ test/tmp
17
+ test/version_tmp
18
+ tmp
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in stupeflix.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2013 paul
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,52 @@
1
+ # stupeflix
2
+
3
+ Stupeflix API (http://developer.stupeflix.com/) wrapper using HTTParty.
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ gem 'stupeflix'
10
+
11
+ And then execute:
12
+
13
+ $ bundle
14
+
15
+ Or install it yourself as:
16
+
17
+ $ gem install stupeflix
18
+
19
+ ## Usage
20
+
21
+ Retrieve your API keys from http://developer.stupeflix.com/keychain/ and then replace the placeholder variables below.
22
+
23
+ s = Stupeflix.new YOUR_ACCESS_KEY, YOUR_SECRET_KEY, 'user/resource'
24
+ id = 'some_unique_identifier'
25
+
26
+ # To PUT a video definition
27
+ s.put_definition definition_xml, id
28
+
29
+ # POST profiles to request videos be generated accordingly
30
+ s.post_profiles profiles_xml, id
31
+
32
+ # GET status of requested videos
33
+ s.status id
34
+
35
+ Follow [this link](http://stupeflix-api.readthedocs.org/en/latest/resources/04_video_description_langage.html) for more
36
+ information about how to produce a definition. I recommend Nokogiri's XML builder.
37
+
38
+ An example of profile XML:
39
+ ```xml
40
+ <profiles><profile name="720p"><stupeflixStore></stupeflixStore></profile></profiles>
41
+ ```
42
+
43
+ Follow [this link](http://wiki.stupeflix.com/doku.php?id=profiles) for a list of supported profile types. Videos will be
44
+ generated for each profile.
45
+
46
+ ## Contributing
47
+
48
+ 1. Fork it
49
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
50
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
51
+ 4. Push to the branch (`git push origin my-new-feature`)
52
+ 5. Create new Pull Request
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
@@ -0,0 +1,6 @@
1
+ class Stupeflix
2
+ VERSION = '0.0.1'
3
+ def self.version
4
+ VERSION
5
+ end
6
+ end
data/lib/stupeflix.rb ADDED
@@ -0,0 +1,50 @@
1
+ require 'stupeflix/version'
2
+ require 'httparty'
3
+
4
+ class Stupeflix
5
+ include HTTParty
6
+ base_uri 'services.stupeflix.com'
7
+
8
+ def initialize key, secret, id_prefix
9
+ @key, @secret, @prefix = key, secret, id_prefix
10
+ self.class.default_params AccessKey: key
11
+ end
12
+
13
+ def req method, body, mime, t, url
14
+ md5hex, md5base64 = md5(body) rescue [nil, nil] # md5hex can be compared to etag in response for verification
15
+ [{ Date: t, Signature: sign([method, md5base64, mime, t, url, nil]*"\n") },
16
+ body ? { 'Content-MD5' => md5base64.to_s, 'Content-Length' => body.length.to_s, 'Content-Type' => mime } : nil]
17
+ end
18
+
19
+ def put_definition d, id=Time.now.to_i
20
+ params, headers = req('PUT', d, 'text/xml', Time.now.to_i, url = "#{url id}/definition/")
21
+ self.class.put url, query: params, headers: headers, body: d
22
+ end
23
+
24
+ def post_profiles profiles, id=Time.now.to_i
25
+ params, headers = req('POST', body = "ProfilesXML=#{CGI::escape profiles}",
26
+ 'application/x-www-form-urlencoded', Time.now.to_i, url = "#{url id}/")
27
+ self.class.post url, query: params, headers: headers, body: body
28
+ end
29
+
30
+ def status id=Time.now.to_i
31
+ params, headers = req('GET', nil, nil, Time.now.to_i, url = "#{url id}/status/")
32
+ r = self.class.get url, query: params #, format: :json
33
+ r.parsed_response rescue r
34
+ end
35
+
36
+ def url id
37
+ "/stupeflix-1.0/#{@prefix}#{id}"
38
+ end
39
+
40
+ protected
41
+
42
+ def sign str
43
+ OpenSSL::HMAC.hexdigest OpenSSL::Digest::Digest.new('sha1'), @secret, str
44
+ end
45
+
46
+ def md5 body
47
+ md5 = Digest::MD5.new().update body
48
+ [md5.hexdigest, Base64.encode64(md5.digest).strip]
49
+ end
50
+ end
data/stupeflix.gemspec ADDED
@@ -0,0 +1,22 @@
1
+ # -*- encoding: utf-8 -*-
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'stupeflix/version'
5
+
6
+ Gem::Specification.new do |gem|
7
+ gem.name = 'stupeflix'
8
+ gem.version = Stupeflix.version
9
+ gem.platform = Gem::Platform::RUBY
10
+ gem.authors = ['Paul Geraghty']
11
+ gem.email = ['muse@appsthatcould.be']
12
+ gem.description = %q{Stupeflix API wrapper using HTTParty}
13
+ gem.summary = %q{Stupeflix API wrapper using HTTParty}
14
+ gem.homepage = 'https://github.com/pgeraghty/stupeflix-api'
15
+
16
+ gem.files = `git ls-files`.split($/)
17
+ gem.executables = gem.files.grep(%r{^bin/}).map{ |f| File.basename(f) }
18
+ gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
19
+ gem.require_paths = ['lib']
20
+
21
+ gem.add_dependency 'httparty', '>= 0'
22
+ end
metadata ADDED
@@ -0,0 +1,69 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: stupeflix
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Paul Geraghty
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2013-02-14 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: httparty
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ! '>='
20
+ - !ruby/object:Gem::Version
21
+ version: '0'
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ! '>='
28
+ - !ruby/object:Gem::Version
29
+ version: '0'
30
+ description: Stupeflix API wrapper using HTTParty
31
+ email:
32
+ - muse@appsthatcould.be
33
+ executables: []
34
+ extensions: []
35
+ extra_rdoc_files: []
36
+ files:
37
+ - .gitignore
38
+ - Gemfile
39
+ - LICENSE.txt
40
+ - README.md
41
+ - Rakefile
42
+ - lib/stupeflix.rb
43
+ - lib/stupeflix/version.rb
44
+ - stupeflix.gemspec
45
+ homepage: https://github.com/pgeraghty/stupeflix-api
46
+ licenses: []
47
+ post_install_message:
48
+ rdoc_options: []
49
+ require_paths:
50
+ - lib
51
+ required_ruby_version: !ruby/object:Gem::Requirement
52
+ none: false
53
+ requirements:
54
+ - - ! '>='
55
+ - !ruby/object:Gem::Version
56
+ version: '0'
57
+ required_rubygems_version: !ruby/object:Gem::Requirement
58
+ none: false
59
+ requirements:
60
+ - - ! '>='
61
+ - !ruby/object:Gem::Version
62
+ version: '0'
63
+ requirements: []
64
+ rubyforge_project:
65
+ rubygems_version: 1.8.24
66
+ signing_key:
67
+ specification_version: 3
68
+ summary: Stupeflix API wrapper using HTTParty
69
+ test_files: []