Class: Roda::RodaPlugins::Middleware::Forwarder
- Inherits:
-
Object
- Object
- Roda::RodaPlugins::Middleware::Forwarder
- Defined in:
- lib/roda/plugins/middleware.rb
Overview
Forward instances are what is actually used as middleware.
Instance Method Summary collapse
-
#call(env) ⇒ Object
When calling the middleware, first call the current middleware.
-
#initialize(mid, app, *args, &block) ⇒ Forwarder
constructor
Store the current middleware and the next middleware to call.
Constructor Details
#initialize(mid, app, *args, &block) ⇒ Forwarder
Store the current middleware and the next middleware to call.
83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/roda/plugins/middleware.rb', line 83 def initialize(mid, app, *args, &block) @mid = if configure = mid.opts[:middleware_configure] mid = Class.new(mid) configure.call(mid, *args, &block) mid else raise RodaError, "cannot provide middleware args or block unless loading middleware plugin with a block" if block || !args.empty? mid end @app = app end |
Instance Method Details
#call(env) ⇒ Object
When calling the middleware, first call the current middleware. If this returns a result, return that result directly. Otherwise, pass handling of the request to the next middleware.
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 |
# File 'lib/roda/plugins/middleware.rb', line 98 def call(env) res = nil call_next = catch(:next) do env[@mid.opts[:middleware_env_var]] = true res = @mid.call(env) false end if call_next @app.call(env) else res end end |