Class: Rack::TokenAuth
- Inherits:
-
Object
- Object
- Rack::TokenAuth
- Defined in:
- lib/rack/token_auth.rb,
lib/rack/token_auth/version.rb
Constant Summary collapse
- UnprocessableHeader =
Class.new(ArgumentError)
- VERSION =
"0.2.0"
Instance Method Summary collapse
- #call(env) ⇒ Object
- #default_unauthorized_app ⇒ Object
- #default_unprocessable_header_app ⇒ Object
-
#initialize(app, options = {}, &block) ⇒ TokenAuth
constructor
A new instance of TokenAuth.
-
#token_and_options(header) ⇒ Object
Taken and adapted from Rails github.com/rails/rails/blob/master/actionpack/lib/action_controller/metal/http_authentication.rb.
- #unauthorized_app ⇒ Object
- #unprocessable_header_app ⇒ Object
Constructor Details
#initialize(app, options = {}, &block) ⇒ TokenAuth
Returns a new instance of TokenAuth.
10 11 12 13 14 |
# File 'lib/rack/token_auth.rb', line 10 def initialize(app, = {}, &block) @app = app = @block = block end |
Instance Method Details
#call(env) ⇒ Object
16 17 18 19 20 21 22 23 24 25 |
# File 'lib/rack/token_auth.rb', line 16 def call(env) token, = *(env["HTTP_AUTHORIZATION"]) if @block.call(token, , env) @app.call(env) else .call(env) end rescue UnprocessableHeader unprocessable_header_app.call(env) end |
#default_unauthorized_app ⇒ Object
39 40 41 |
# File 'lib/rack/token_auth.rb', line 39 def lambda { |_env| Rack::Response.new("Unauthorized", 401).to_a } end |
#default_unprocessable_header_app ⇒ Object
35 36 37 |
# File 'lib/rack/token_auth.rb', line 35 def default_unprocessable_header_app lambda { |_env| Rack::Response.new("Unprocessable Authorization header", 400).to_a } end |
#token_and_options(header) ⇒ Object
Taken and adapted from Rails github.com/rails/rails/blob/master/actionpack/lib/action_controller/metal/http_authentication.rb
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'lib/rack/token_auth.rb', line 45 def (header) token = header.to_s.match(/^Token (.*)/) { |m| m[1] } if token begin values = Hash[token.split(",").map do |value| value.strip! # remove any spaces between commas and values key, value = value.split(/="?/) # split key=value pairs value.chomp!('"') # chomp trailing " in value value.gsub!(/\\"/, '"') # unescape remaining quotes [key, value] end] [values.delete("token"), values] rescue StandardError => exception raise UnprocessableHeader, exception end else [nil, {}] end end |
#unauthorized_app ⇒ Object
27 28 29 |
# File 'lib/rack/token_auth.rb', line 27 def .fetch(:unauthorized_app) { } end |
#unprocessable_header_app ⇒ Object
31 32 33 |
# File 'lib/rack/token_auth.rb', line 31 def unprocessable_header_app .fetch(:unprocessable_header_app) { default_unprocessable_header_app } end |