Class: RailsMcp::Auth::TokenValidator
- Inherits:
-
Object
- Object
- RailsMcp::Auth::TokenValidator
- Defined in:
- lib/rails_mcp/auth/token_validator.rb
Constant Summary collapse
- WELL_KNOWN_PREFIX =
"/.well-known/"
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app) ⇒ TokenValidator
constructor
A new instance of TokenValidator.
Constructor Details
#initialize(app) ⇒ TokenValidator
Returns a new instance of TokenValidator.
8 9 10 |
# File 'lib/rails_mcp/auth/token_validator.rb', line 8 def initialize(app) @app = app end |
Instance Method Details
#call(env) ⇒ Object
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'lib/rails_mcp/auth/token_validator.rb', line 12 def call(env) request = Rack::Request.new(env) # CORS preflight and public discovery endpoints bypass auth return @app.call(env) if request. return @app.call(env) if request.path.start_with?(WELL_KNOWN_PREFIX) token_string = extract_bearer_token(env) return ("Bearer token required") if token_string.nil? token = Doorkeeper::AccessToken.by_token(token_string) return ("Invalid or expired token") if token.nil? || token.revoked? || token.expired? required = RailsMcp.configuration.scope return insufficient_scope(required) if required && !required.empty? && !token.scopes.include?(required) env["rails_mcp.access_token"] = token @app.call(env) end |