Class: Rack::AI::Middleware
- Inherits:
-
Object
- Object
- Rack::AI::Middleware
- Defined in:
- lib/rack/ai/middleware.rb
Instance Attribute Summary collapse
-
#app ⇒ Object
readonly
Returns the value of attribute app.
-
#config ⇒ Object
readonly
Returns the value of attribute config.
-
#features ⇒ Object
readonly
Returns the value of attribute features.
-
#provider ⇒ Object
readonly
Returns the value of attribute provider.
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, **options) ⇒ Middleware
constructor
A new instance of Middleware.
Constructor Details
#initialize(app, **options) ⇒ Middleware
10 11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/rack/ai/middleware.rb', line 10 def initialize(app, **) @app = app @config = build_config() @provider = build_provider @features = build_features @thread_pool = Concurrent::ThreadPoolExecutor.new( min_threads: 2, max_threads: 10, max_queue: 100 ) validate_configuration! end |
Instance Attribute Details
#app ⇒ Object (readonly)
Returns the value of attribute app.
8 9 10 |
# File 'lib/rack/ai/middleware.rb', line 8 def app @app end |
#config ⇒ Object (readonly)
Returns the value of attribute config.
8 9 10 |
# File 'lib/rack/ai/middleware.rb', line 8 def config @config end |
#features ⇒ Object (readonly)
Returns the value of attribute features.
8 9 10 |
# File 'lib/rack/ai/middleware.rb', line 8 def features @features end |
#provider ⇒ Object (readonly)
Returns the value of attribute provider.
8 9 10 |
# File 'lib/rack/ai/middleware.rb', line 8 def provider @provider end |
Instance Method Details
#call(env) ⇒ Object
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/rack/ai/middleware.rb', line 24 def call(env) # Initialize AI context in env env["rack.ai"] = { results: {}, metadata: {}, start_time: Time.now } # Process request through AI features blocked_response = process_request(env) if should_process_request?(env) # Return blocked response if request should be blocked return blocked_response if blocked_response # Call the next middleware/app status, headers, body = @app.call(env) # Process response through AI features process_response(env, status, headers, body) if should_process_response?(env) # Add AI headers if configured add_ai_headers(headers, env) if @config.explain_decisions [status, headers, body] rescue => e handle_error(e, env) # Fail-safe: continue with original request if AI processing fails @config.fail_safe ? @app.call(env) : raise ensure # Record metrics record_metrics(env) if @config.metrics_enabled end |