Class: PactBroker::App
- Inherits:
-
Object
- Object
- PactBroker::App
- Includes:
- Logging
- Defined in:
- lib/pact_broker/app.rb
Instance Attribute Summary collapse
-
#configuration ⇒ Object
Returns the value of attribute configuration.
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize {|configuration| ... } ⇒ App
constructor
A new instance of App.
-
#use(*args, &block) ⇒ Object
Allows middleware to be inserted at the bottom of the shared middlware stack (ie just before the cascade is called for diagnostic, UI and API).
-
#use_api_auth(middleware) ⇒ Object
private API, not sure if this will continue to be supported.
- #use_custom_api(custom_api) ⇒ Object
- #use_custom_ui(custom_ui) ⇒ Object
- #use_to_create_pact_broker_api(&block) ⇒ Object
-
#use_ui_auth(middleware) ⇒ Object
private API, not sure if this will continue to be supported.
Methods included from Logging
included, #log_error, #log_with_tag
Constructor Details
#initialize {|configuration| ... } ⇒ App
Returns a new instance of App.
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/pact_broker/app.rb', line 42 def initialize @app_builder = ::Rack::Builder.new @cascade_apps = [] @make_it_later_api_auth = ::Rack::PactBroker::ConfigurableMakeItLater.new(Rack::PactBroker::NoAuth) @make_it_later_ui_auth = ::Rack::PactBroker::ConfigurableMakeItLater.new(Rack::PactBroker::NoAuth) # Can only be required after database connection has been made because the decorators rely on the Sequel models @create_pact_broker_api_block = ->() { require "pact_broker/api"; PactBroker::API } @configuration = PactBroker.configuration yield configuration if block_given? post_configure prepare_database load_configuration_from_database seed_example_data @configuration.freeze end |
Instance Attribute Details
#configuration ⇒ Object
Returns the value of attribute configuration.
40 41 42 |
# File 'lib/pact_broker/app.rb', line 40 def configuration @configuration end |
Instance Method Details
#call(env) ⇒ Object
90 91 92 |
# File 'lib/pact_broker/app.rb', line 90 def call env running_app.call env end |
#use(*args, &block) ⇒ Object
Allows middleware to be inserted at the bottom of the shared middlware stack (ie just before the cascade is called for diagnostic, UI and API). To insert middleware at the top of the stack, initialize the middleware with the app, and run it manually. eg run MyMiddleware.new(app)
64 65 66 |
# File 'lib/pact_broker/app.rb', line 64 def use *args, &block @app_builder.use(*args, &block) end |
#use_api_auth(middleware) ⇒ Object
private API, not sure if this will continue to be supported
69 70 71 |
# File 'lib/pact_broker/app.rb', line 69 def use_api_auth middleware @make_it_later_api_auth.make_it_later(middleware) end |
#use_custom_api(custom_api) ⇒ Object
82 83 84 |
# File 'lib/pact_broker/app.rb', line 82 def use_custom_api custom_api @custom_api = custom_api end |
#use_custom_ui(custom_ui) ⇒ Object
78 79 80 |
# File 'lib/pact_broker/app.rb', line 78 def use_custom_ui custom_ui @custom_ui = custom_ui end |
#use_to_create_pact_broker_api(&block) ⇒ Object
86 87 88 |
# File 'lib/pact_broker/app.rb', line 86 def use_to_create_pact_broker_api &block @create_pact_broker_api_block = block end |
#use_ui_auth(middleware) ⇒ Object
private API, not sure if this will continue to be supported
74 75 76 |
# File 'lib/pact_broker/app.rb', line 74 def use_ui_auth middleware @make_it_later_ui_auth.make_it_later(middleware) end |