Sha256: 5513b2864763e49cfbc936181617f39b143c47d9113d037e6242dcceae0dc736
Contents?: true
Size: 1.83 KB
Versions: 1
Compression:
Stored size: 1.83 KB
Contents
# frozen_string_literal: true require "rack/token_auth/version" module Rack class TokenAuth UnprocessableHeader = Class.new(ArgumentError) def initialize(app, options = {}, &block) @app = app @options = options @block = block end def call(env) token, options = *token_and_options(env["HTTP_AUTHORIZATION"]) if @block.call(token, options, env) @app.call(env) else unauthorized_app.call(env) end rescue UnprocessableHeader unprocessable_header_app.call(env) end def unauthorized_app @options.fetch(:unauthorized_app) { default_unauthorized_app } end def unprocessable_header_app @options.fetch(:unprocessable_header_app) { default_unprocessable_header_app } end def default_unprocessable_header_app lambda { |_env| Rack::Response.new("Unprocessable Authorization header", 400).to_a } end def default_unauthorized_app lambda { |_env| Rack::Response.new("Unauthorized", 401).to_a } end # Taken and adapted from Rails # https://github.com/rails/rails/blob/master/actionpack/lib/action_controller/metal/http_authentication.rb def token_and_options(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 end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rack-token_auth-0.2.0 | lib/rack/token_auth.rb |