Class: RackApiVersioning::Middleware
- Inherits:
-
Object
- Object
- RackApiVersioning::Middleware
- Defined in:
- lib/rack_api_versioning/middleware.rb
Instance Method Summary collapse
-
#api_version_error ⇒ Object
Subclass and override this method if you’d like an alternate behavior.
- #call(env) ⇒ Object
-
#initialize(app, options = {}) ⇒ Middleware
constructor
Valid options include the same options the RackApiVersioning::Constraint class uses.
Constructor Details
#initialize(app, options = {}) ⇒ Middleware
Valid options include the same options the RackApiVersioning::Constraint class uses. Specifically:
:target_version => This is the API version you want to use, when left unspecified it defaults to 1.
:default_version => This is the API version to failover to, when left unspecified it defaults to 1.
:app_name => The app name that should be included in the 'Accept'
header, when left unspecified it defaults to “api”.
:media_type => The desired media type the API should respond with, when left unspecified it defaults to “*”.
24 25 26 27 |
# File 'lib/rack_api_versioning/middleware.rb', line 24 def initialize(app, = {}) @app = app @api_version_constraint = Constraint.new() end |
Instance Method Details
#api_version_error ⇒ Object
Subclass and override this method if you’d like an alternate behavior.
39 40 41 42 43 |
# File 'lib/rack_api_versioning/middleware.rb', line 39 def api_version_error body_text = "The request did not contain an appropriate API version header." [400, {'Content-Type' => 'text/plain; charset=utf-8', 'Content-Length' => body_text.size.to_s}, [body_text]] end |
#call(env) ⇒ Object
29 30 31 32 33 34 35 |
# File 'lib/rack_api_versioning/middleware.rb', line 29 def call(env) if @api_version_constraint.matches?(env) @app.call(env) else api_version_error end end |