roo_on_rails 1.21.0 → 2.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/.circleci/config.yml +446 -150
- data/.circleci/config.yml.erb +63 -18
- data/.codecov.yml +3 -0
- data/Appraisals +17 -11
- data/CHANGELOG.md +38 -0
- data/README.md +23 -74
- data/appraise +1 -1
- data/exe/roo_on_rails +5 -0
- data/gemfiles/rails_4.gemfile +3 -1
- data/gemfiles/rails_5.gemfile +2 -1
- data/gemfiles/rails_5_1.gemfile +2 -1
- data/gemfiles/rails_5_2.gemfile +2 -1
- data/gemfiles/{rails_3.gemfile → rails_6.gemfile} +5 -4
- data/lib/roo_on_rails.rb +0 -3
- data/lib/roo_on_rails/checks/documentation/playbook_template.md +0 -4
- data/lib/roo_on_rails/concerns/require_api_key.rb +0 -1
- data/lib/roo_on_rails/config.rb +0 -8
- data/lib/roo_on_rails/default.env +0 -13
- data/lib/roo_on_rails/rack/populate_env_from_jwt.rb +26 -4
- data/lib/roo_on_rails/railties/database.rb +11 -10
- data/lib/roo_on_rails/railties/env.rb +3 -5
- data/lib/roo_on_rails/railties/google_oauth.rb +4 -6
- data/lib/roo_on_rails/railties/http.rb +34 -32
- data/lib/roo_on_rails/railties/roo_identity.rb +12 -8
- data/lib/roo_on_rails/railties/sidekiq_integration.rb +7 -19
- data/lib/roo_on_rails/version.rb +1 -1
- data/roo_on_rails.gemspec +4 -6
- metadata +24 -68
- data/.travis.yml +0 -34
- data/README.routemaster_client.md +0 -103
- data/lib/roo_on_rails/railties/logging.rb +0 -25
- data/lib/roo_on_rails/railties/new_relic.rb +0 -32
- data/lib/roo_on_rails/railties/routemaster.rb +0 -42
- data/lib/roo_on_rails/routemaster/lifecycle_events.rb +0 -64
- data/lib/roo_on_rails/routemaster/publish_lifecycle_events.rb +0 -13
- data/lib/roo_on_rails/routemaster/publisher.rb +0 -74
- data/lib/roo_on_rails/routemaster/publishers.rb +0 -27
- data/lib/roo_on_rails/tasks/newrelic.rake +0 -25
    
        data/lib/roo_on_rails.rb
    CHANGED
    
    | @@ -5,14 +5,11 @@ end | |
| 5 5 |  | 
| 6 6 | 
             
            if defined?(Rails)
         | 
| 7 7 | 
             
              require 'dotenv/rails-now'
         | 
| 8 | 
            -
              require 'roo_on_rails/railties/logging'
         | 
| 9 8 | 
             
              require 'roo_on_rails/railties/env'
         | 
| 10 | 
            -
              require 'roo_on_rails/railties/new_relic'
         | 
| 11 9 | 
             
              require 'roo_on_rails/railties/database'
         | 
| 12 10 | 
             
              require 'roo_on_rails/railties/http'
         | 
| 13 11 | 
             
              require 'roo_on_rails/railties/sidekiq_integration'
         | 
| 14 12 | 
             
              require 'roo_on_rails/railties/rake_tasks'
         | 
| 15 13 | 
             
              require 'roo_on_rails/railties/google_oauth'
         | 
| 16 | 
            -
              require 'roo_on_rails/railties/routemaster'
         | 
| 17 14 | 
             
              require 'roo_on_rails/railties/roo_identity'
         | 
| 18 15 | 
             
            end
         | 
| @@ -20,10 +20,6 @@ As a last resort, in an emergency, the following people have experience working | |
| 20 20 |  | 
| 21 21 | 
             
            FIXME: A very brief high-level explanation of what this functional area does
         | 
| 22 22 |  | 
| 23 | 
            -
            #### 🚨 FIXME: a New Relic alert which might be raised - named so it can be searched for
         | 
| 24 | 
            -
             | 
| 25 | 
            -
            FIXME: A description of the New Relic alert, what it means for the service, and what actions should be taken to remedy the situation.
         | 
| 26 | 
            -
             | 
| 27 23 | 
             
            #### 🚨 FIXME: an action which might need to be taken during an incident
         | 
| 28 24 |  | 
| 29 25 | 
             
            FIXME: A description of how to perform this action, and any side-effects that the on-call engineer should be aware of.
         | 
| @@ -58,7 +58,6 @@ module RooOnRails | |
| 58 58 | 
             
                    def valid?(service_name, client_key)
         | 
| 59 59 | 
             
                      return false unless whitelisted?(service_name)
         | 
| 60 60 |  | 
| 61 | 
            -
                      NewRelic::Agent.add_custom_attributes(httpBasicUserId: service_name) if defined?(NewRelic)
         | 
| 62 61 | 
             
                      ClientApiKeys.instance.valid?(service_name, client_key)
         | 
| 63 62 | 
             
                    end
         | 
| 64 63 |  | 
    
        data/lib/roo_on_rails/config.rb
    CHANGED
    
    | @@ -25,14 +25,6 @@ module RooOnRails | |
| 25 25 | 
             
                    ENV.fetch('GOOGLE_AUTH_CONTROLLER')
         | 
| 26 26 | 
             
                  end
         | 
| 27 27 |  | 
| 28 | 
            -
                  def routemaster_enabled?
         | 
| 29 | 
            -
                    enabled? 'ROUTEMASTER_ENABLED', default: false
         | 
| 30 | 
            -
                  end
         | 
| 31 | 
            -
             | 
| 32 | 
            -
                  def routemaster_publishing_enabled?
         | 
| 33 | 
            -
                    enabled? 'ROUTEMASTER_PUBLISHING_ENABLED', default: false
         | 
| 34 | 
            -
                  end
         | 
| 35 | 
            -
             | 
| 36 28 | 
             
                  private
         | 
| 37 29 |  | 
| 38 30 | 
             
                  ENABLED_PATTERN = /\A(YES|TRUE|ON|1)\Z/i
         | 
| @@ -4,21 +4,8 @@ GOOGLE_AUTH_CLIENT_SECRET='' | |
| 4 4 | 
             
            GOOGLE_AUTH_ALLOWED_DOMAINS=''
         | 
| 5 5 | 
             
            GOOGLE_AUTH_PATH_PREFIX=/auth
         | 
| 6 6 | 
             
            GOOGLE_AUTH_CONTROLLER=sessions
         | 
| 7 | 
            -
            NEW_RELIC_LOG=stdout
         | 
| 8 | 
            -
            NEW_RELIC_AGENT_ENABLED=true
         | 
| 9 | 
            -
            NEW_RELIC_MONITOR_MODE=true
         | 
| 10 | 
            -
            NEW_RELIC_BROWSER_MONITORING_AUTO_INSTRUMENT=true
         | 
| 11 | 
            -
            NEW_RELIC_CAPTURE_PARAMS=true
         | 
| 12 | 
            -
            NEW_RELIC_TRANSACTION_TRACER_RECORD_SQL=obfuscated
         | 
| 13 | 
            -
            NEW_RELIC_TRANSACTION_TRACER_RECORD_REDIS_ARGUMENTS=true
         | 
| 14 | 
            -
            NEW_RELIC_DEVELOPER_MODE=false
         | 
| 15 | 
            -
            NEW_RELIC_LICENSE_KEY=override-me
         | 
| 16 7 | 
             
            RACK_SERVICE_TIMEOUT=10
         | 
| 17 8 | 
             
            RACK_WAIT_TIMEOUT=30
         | 
| 18 | 
            -
            ROUTEMASTER_URL=''
         | 
| 19 | 
            -
            ROUTEMASTER_UUID=''
         | 
| 20 | 
            -
            ROUTEMASTER_ENABLED=false
         | 
| 21 | 
            -
            ROUTEMASTER_PUBLISHING_ENABLED=false
         | 
| 22 9 | 
             
            SIDEKIQ_ENABLED=true
         | 
| 23 10 | 
             
            SIDEKIQ_THREADS=25
         | 
| 24 11 | 
             
            SIDEKIQ_DATABASE_REAPING_FREQUENCY=10
         | 
| @@ -7,15 +7,23 @@ module RooOnRails | |
| 7 7 | 
             
                class PopulateEnvFromJWT
         | 
| 8 8 | 
             
                  UnacceptableKeyError = Class.new(RuntimeError)
         | 
| 9 9 | 
             
                  VALID_PREFIXES_KEY = 'VALID_IDENTITY_URL_PREFIXES'.freeze
         | 
| 10 | 
            +
                  DEFAULT_MAPPED_URLS = {
         | 
| 11 | 
            +
                    'https://test.deliveroo.co.uk/' => 'https://orderweb.rooenv-staging.io/',
         | 
| 12 | 
            +
                    'https://deliveroo.co.uk/' => 'https://orderweb.deliverooapp.com/',
         | 
| 13 | 
            +
                    'https://identity-staging.deliveroo.com/' => 'https://internal-identity.rooenv-staging.io/',
         | 
| 14 | 
            +
                    'https://identity.deliveroo.com/' => 'https://internal-identity.deliverooapp.com/'
         | 
| 15 | 
            +
                  }.freeze
         | 
| 10 16 |  | 
| 11 17 | 
             
                  def self.configured?
         | 
| 12 18 | 
             
                    ENV[VALID_PREFIXES_KEY].present?
         | 
| 13 19 | 
             
                  end
         | 
| 14 20 |  | 
| 15 | 
            -
                  def initialize(app, logger:, skip_sig_verify: true)
         | 
| 21 | 
            +
                  def initialize(app, logger:, skip_sig_verify: true, url_mappings: DEFAULT_MAPPED_URLS)
         | 
| 16 22 | 
             
                    @app = app
         | 
| 17 | 
            -
                    @keys = {}
         | 
| 18 23 | 
             
                    @logger = logger
         | 
| 24 | 
            +
                    @url_mappings = url_mappings
         | 
| 25 | 
            +
                    @keys = {}
         | 
| 26 | 
            +
                    @mapped_urls = {}
         | 
| 19 27 |  | 
| 20 28 | 
             
                    if skip_sig_verify && non_prod?
         | 
| 21 29 | 
             
                      @logger.warn "JWTs signature verifification has been switched off in development."
         | 
| @@ -34,7 +42,7 @@ module RooOnRails | |
| 34 42 | 
             
                  rescue UnacceptableKeyError, JSON::JWT::Exception => e
         | 
| 35 43 | 
             
                    # Identifying user is clearly attempting to hack or has been given a totally incorrect
         | 
| 36 44 | 
             
                    # token, log this and flag as Forbidden, without executing the rest of the middleware stack.
         | 
| 37 | 
            -
                     | 
| 45 | 
            +
                    Raven.report_exception(e) if defined?(Raven)
         | 
| 38 46 | 
             
                    [401, {}, []]
         | 
| 39 47 | 
             
                  end
         | 
| 40 48 |  | 
| @@ -86,7 +94,7 @@ module RooOnRails | |
| 86 94 | 
             
                    return @keys[key_url] if @keys.key?(key_url)
         | 
| 87 95 |  | 
| 88 96 | 
             
                    @logger.info "Downloading identity public key from #{key_url}"
         | 
| 89 | 
            -
                    json = http_request.get(key_url).body
         | 
| 97 | 
            +
                    json = http_request.get(mapped_url(key_url)).body
         | 
| 90 98 | 
             
                    @keys[key_url] = JSON::JWK.new(json)
         | 
| 91 99 | 
             
                  rescue Faraday::ParsingError
         | 
| 92 100 | 
             
                    raise JSON::JWT::InvalidFormat, 'Downloaded JWK is not a valid JSON file'
         | 
| @@ -101,6 +109,20 @@ module RooOnRails | |
| 101 109 | 
             
                      conf.adapter Faraday.default_adapter
         | 
| 102 110 | 
             
                    end
         | 
| 103 111 | 
             
                  end
         | 
| 112 | 
            +
             | 
| 113 | 
            +
                  # Allows us to use internal URLs instead of external ones where appropriate
         | 
| 114 | 
            +
                  def mapped_url(url)
         | 
| 115 | 
            +
                    return @mapped_urls[url] unless @mapped_urls[url].nil?
         | 
| 116 | 
            +
             | 
| 117 | 
            +
                    @url_mappings.each do |prefix, replacement|
         | 
| 118 | 
            +
                      next unless url.starts_with?(prefix)
         | 
| 119 | 
            +
                      mapped = url.sub(prefix, replacement)
         | 
| 120 | 
            +
                      @mapped_urls[url] = mapped
         | 
| 121 | 
            +
                      return mapped
         | 
| 122 | 
            +
                    end
         | 
| 123 | 
            +
             | 
| 124 | 
            +
                    url
         | 
| 125 | 
            +
                  end
         | 
| 104 126 | 
             
                end
         | 
| 105 127 | 
             
              end
         | 
| 106 128 | 
             
            end
         | 
| @@ -3,18 +3,19 @@ module RooOnRails | |
| 3 3 | 
             
                class Database < Rails::Railtie
         | 
| 4 4 | 
             
                  initializer 'roo_on_rails.database', after: 'active_record.initialize_database' do
         | 
| 5 5 | 
             
                    ActiveSupport.on_load :active_record do
         | 
| 6 | 
            -
                      Rails.logger. | 
| 7 | 
            -
                        log.debug 'loading'
         | 
| 6 | 
            +
                      Rails.logger.debug('[roo_on_rails.database] loading')
         | 
| 8 7 |  | 
| 9 | 
            -
             | 
| 10 | 
            -
             | 
| 11 | 
            -
             | 
| 12 | 
            -
             | 
| 13 | 
            -
             | 
| 14 | 
            -
                         | 
| 15 | 
            -
             | 
| 16 | 
            -
             | 
| 8 | 
            +
                      config = ActiveRecord::Base.configurations[Rails.env]
         | 
| 9 | 
            +
                      config['variables'] ||= {}
         | 
| 10 | 
            +
                      statement_timeout = ENV.fetch('DATABASE_STATEMENT_TIMEOUT', 200)
         | 
| 11 | 
            +
                      # Use -1 to disable setting the statement timeout
         | 
| 12 | 
            +
                      unless statement_timeout == '-1'
         | 
| 13 | 
            +
                        config['variables']['statement_timeout'] = statement_timeout
         | 
| 14 | 
            +
                      end
         | 
| 15 | 
            +
                      if ENV.key?('DATABASE_REAPING_FREQUENCY')
         | 
| 16 | 
            +
                        config['reaping_frequency'] = ENV['DATABASE_REAPING_FREQUENCY']
         | 
| 17 17 | 
             
                      end
         | 
| 18 | 
            +
                      ActiveRecord::Base.establish_connection
         | 
| 18 19 | 
             
                    end
         | 
| 19 20 | 
             
                  end
         | 
| 20 21 | 
             
                end
         | 
| @@ -1,11 +1,9 @@ | |
| 1 1 | 
             
            module RooOnRails
         | 
| 2 2 | 
             
              class Railtie < Rails::Railtie
         | 
| 3 3 | 
             
                initializer 'roo_on_rails.default_env' do
         | 
| 4 | 
            -
                  Rails.logger. | 
| 5 | 
            -
             | 
| 6 | 
            -
             | 
| 7 | 
            -
                    RooOnRails::Environment.load
         | 
| 8 | 
            -
                  end
         | 
| 4 | 
            +
                  Rails.logger.debug '[roo_on_rails.default_env] loading'
         | 
| 5 | 
            +
                  require 'roo_on_rails/environment'
         | 
| 6 | 
            +
                  RooOnRails::Environment.load
         | 
| 9 7 | 
             
                end
         | 
| 10 8 | 
             
              end
         | 
| 11 9 | 
             
            end
         | 
| @@ -4,12 +4,10 @@ module RooOnRails | |
| 4 4 | 
             
              module Railties
         | 
| 5 5 | 
             
                class GoogleOAuth < Rails::Railtie
         | 
| 6 6 | 
             
                  initializer 'roo_on_rails.google_auth.middleware' do |app|
         | 
| 7 | 
            -
                     | 
| 8 | 
            -
             | 
| 9 | 
            -
             | 
| 10 | 
            -
             | 
| 11 | 
            -
                      _add_routes(app)
         | 
| 12 | 
            -
                    end
         | 
| 7 | 
            +
                    next unless Config.google_auth_enabled?
         | 
| 8 | 
            +
                    Rails.logger.debug '[roo_on_rails.google_auth] loading'
         | 
| 9 | 
            +
                    _add_middleware(app)
         | 
| 10 | 
            +
                    _add_routes(app)
         | 
| 13 11 | 
             
                  end
         | 
| 14 12 |  | 
| 15 13 | 
             
                  private
         | 
| @@ -2,45 +2,47 @@ module RooOnRails | |
| 2 2 | 
             
              module Railties
         | 
| 3 3 | 
             
                class HTTP < Rails::Railtie
         | 
| 4 4 | 
             
                  initializer 'roo_on_rails.http' do |app|
         | 
| 5 | 
            -
                    Rails.logger. | 
| 6 | 
            -
                      log.debug 'loading'
         | 
| 5 | 
            +
                    Rails.logger.debug '[roo_on_rails.http] loading'
         | 
| 7 6 |  | 
| 8 | 
            -
             | 
| 9 | 
            -
             | 
| 10 | 
            -
             | 
| 7 | 
            +
                    require 'rack/timeout/base'
         | 
| 8 | 
            +
                    require 'rack/ssl-enforcer'
         | 
| 9 | 
            +
                    require 'roo_on_rails/rack/safe_timeouts'
         | 
| 11 10 |  | 
| 12 | 
            -
             | 
| 11 | 
            +
                    ::Rack::Timeout::Logger.level = ::Logger::WARN
         | 
| 13 12 |  | 
| 14 | 
            -
             | 
| 15 | 
            -
             | 
| 16 | 
            -
             | 
| 17 | 
            -
             | 
| 18 | 
            -
             | 
| 19 | 
            -
             | 
| 13 | 
            +
                    app.config.middleware.insert_before(
         | 
| 14 | 
            +
                      ::Rack::Runtime,
         | 
| 15 | 
            +
                      ::Rack::Timeout,
         | 
| 16 | 
            +
                      service_timeout: ENV.fetch('RACK_SERVICE_TIMEOUT', 15).to_i,
         | 
| 17 | 
            +
                      wait_timeout: ENV.fetch('RACK_WAIT_TIMEOUT', 30).to_i
         | 
| 18 | 
            +
                    )
         | 
| 20 19 |  | 
| 21 | 
            -
             | 
| 20 | 
            +
                    if Rails::VERSION::MAJOR < 4
         | 
| 21 | 
            +
                      middleware_to_insert_before = ::ActionDispatch::Cookies
         | 
| 22 | 
            +
                    else
         | 
| 23 | 
            +
                      middleware_to_insert_before = ::Rack::Head
         | 
| 24 | 
            +
                    end
         | 
| 22 25 |  | 
| 23 | 
            -
             | 
| 24 | 
            -
             | 
| 25 | 
            -
             | 
| 26 | 
            -
             | 
| 27 | 
            -
             | 
| 28 | 
            -
             | 
| 29 | 
            -
             | 
| 30 | 
            -
             | 
| 26 | 
            +
                    # This needs to be inserted low in the stack, before Rails returns the
         | 
| 27 | 
            +
                    # thread-current connection to the pool.
         | 
| 28 | 
            +
                    if defined?(ActiveRecord)
         | 
| 29 | 
            +
                      app.config.middleware.insert_before(
         | 
| 30 | 
            +
                        middleware_to_insert_before,
         | 
| 31 | 
            +
                        RooOnRails::Rack::SafeTimeouts
         | 
| 32 | 
            +
                      )
         | 
| 33 | 
            +
                    end
         | 
| 31 34 |  | 
| 32 | 
            -
             | 
| 33 | 
            -
             | 
| 34 | 
            -
             | 
| 35 | 
            +
                    if ENV.fetch('ROO_ON_RAILS_RACK_DEFLATE', 'YES').to_s =~ /\A(YES|TRUE|ON|1)\Z/i
         | 
| 36 | 
            +
                      app.config.middleware.use ::Rack::Deflater
         | 
| 37 | 
            +
                    end
         | 
| 35 38 |  | 
| 36 | 
            -
             | 
| 37 | 
            -
             | 
| 38 | 
            -
             | 
| 39 | 
            -
             | 
| 40 | 
            -
             | 
| 41 | 
            -
             | 
| 42 | 
            -
             | 
| 43 | 
            -
                      end
         | 
| 39 | 
            +
                    # Don't use SslEnforcer in test environment as it breaks Capybara
         | 
| 40 | 
            +
                    unless Rails.env.test? ||
         | 
| 41 | 
            +
                           ENV.fetch('ROO_ON_RAILS_DISABLE_SSL_ENFORCEMENT', '') =~ /\A(YES|TRUE|ON|1)\Z/i
         | 
| 42 | 
            +
                      app.config.middleware.insert_before(
         | 
| 43 | 
            +
                        middleware_to_insert_before,
         | 
| 44 | 
            +
                        ::Rack::SslEnforcer
         | 
| 45 | 
            +
                      )
         | 
| 44 46 | 
             
                    end
         | 
| 45 47 | 
             
                  end
         | 
| 46 48 | 
             
                end
         | 
| @@ -4,13 +4,14 @@ module RooOnRails | |
| 4 4 | 
             
              module Railties
         | 
| 5 5 | 
             
                class RooIdentity < Rails::Railtie
         | 
| 6 6 | 
             
                  initializer 'roo_on_rails.roo_identity.middleware' do |app|
         | 
| 7 | 
            -
                     | 
| 8 | 
            -
                       | 
| 9 | 
            -
             | 
| 10 | 
            -
             | 
| 11 | 
            -
                       | 
| 12 | 
            -
                         | 
| 13 | 
            -
             | 
| 7 | 
            +
                    if RooOnRails::Rack::PopulateEnvFromJWT.configured?
         | 
| 8 | 
            +
                      Rails.logger.debug '[roo_on_rails.roo_identity.middleware] loading'
         | 
| 9 | 
            +
                      _add_middleware(app, Rails.logger)
         | 
| 10 | 
            +
                    else
         | 
| 11 | 
            +
                      Rails.logger.warn(
         | 
| 12 | 
            +
                        '[roo_on_rails.roo_identity.middleware] ' \
         | 
| 13 | 
            +
                        ' not configured, roo.identity will be unavailable'
         | 
| 14 | 
            +
                      )
         | 
| 14 15 | 
             
                    end
         | 
| 15 16 | 
             
                  end
         | 
| 16 17 |  | 
| @@ -19,7 +20,10 @@ module RooOnRails | |
| 19 20 | 
             
                  def _add_middleware(app, log)
         | 
| 20 21 | 
             
                    app.config.middleware.use RooOnRails::Rack::PopulateEnvFromJWT, logger: log
         | 
| 21 22 | 
             
                  rescue LoadError
         | 
| 22 | 
            -
                    log.error | 
| 23 | 
            +
                    log.error(
         | 
| 24 | 
            +
                      '[roo_on_rails.roo_identity.middleware] ' \
         | 
| 25 | 
            +
                      'the json-jwt gem is not in the bundle so Roo Identity will not be available'
         | 
| 26 | 
            +
                    )
         | 
| 23 27 | 
             
                  end
         | 
| 24 28 | 
             
                end
         | 
| 25 29 | 
             
              end
         | 
| @@ -8,27 +8,15 @@ module RooOnRails | |
| 8 8 | 
             
              module Railties
         | 
| 9 9 | 
             
                class SidekiqIntegration < Rails::Railtie
         | 
| 10 10 | 
             
                  initializer 'roo_on_rails.sidekiq' do |app|
         | 
| 11 | 
            -
                     | 
| 12 | 
            -
                       | 
| 13 | 
            -
             | 
| 14 | 
            -
                        next
         | 
| 15 | 
            -
                      end
         | 
| 16 | 
            -
             | 
| 17 | 
            -
                      log.debug 'loading'
         | 
| 18 | 
            -
                      require 'hirefire-resource'
         | 
| 19 | 
            -
             | 
| 20 | 
            -
                      config_sidekiq
         | 
| 21 | 
            -
                      config_sidekiq_metrics
         | 
| 22 | 
            -
                      config_hirefire(app)
         | 
| 11 | 
            +
                    unless RooOnRails::Config.sidekiq_enabled?
         | 
| 12 | 
            +
                      Rails.logger.debug '[roo_on_rails.sidekiq] skipping'
         | 
| 13 | 
            +
                      next
         | 
| 23 14 | 
             
                    end
         | 
| 24 | 
            -
                  end
         | 
| 25 15 |  | 
| 26 | 
            -
             | 
| 27 | 
            -
             | 
| 28 | 
            -
             | 
| 29 | 
            -
             | 
| 30 | 
            -
                    end
         | 
| 31 | 
            -
                    add_middleware(app)
         | 
| 16 | 
            +
                    Rails.logger.debug '[roo_on_rails.sidekiq] loading'
         | 
| 17 | 
            +
             | 
| 18 | 
            +
                    config_sidekiq
         | 
| 19 | 
            +
                    config_sidekiq_metrics
         | 
| 32 20 | 
             
                  end
         | 
| 33 21 |  | 
| 34 22 | 
             
                  def config_sidekiq
         | 
    
        data/lib/roo_on_rails/version.rb
    CHANGED
    
    
    
        data/roo_on_rails.gemspec
    CHANGED
    
    | @@ -22,23 +22,21 @@ Gem::Specification.new do |spec| | |
| 22 22 | 
             
              spec.require_paths = ['lib']
         | 
| 23 23 |  | 
| 24 24 | 
             
              spec.add_runtime_dependency 'dotenv-rails', '~> 2.1'
         | 
| 25 | 
            -
              spec.add_runtime_dependency ' | 
| 26 | 
            -
              spec.add_runtime_dependency ' | 
| 25 | 
            +
              spec.add_runtime_dependency 'rails', '>= 3.2.22'
         | 
| 26 | 
            +
              spec.add_runtime_dependency 'sprockets', '~>3.0'
         | 
| 27 27 | 
             
              spec.add_runtime_dependency 'platform-api', '~> 2.0'
         | 
| 28 28 | 
             
              spec.add_runtime_dependency 'hashie', '~> 3.4'
         | 
| 29 29 | 
             
              spec.add_runtime_dependency 'rack-timeout', '>= 0.4.0'
         | 
| 30 30 | 
             
              spec.add_runtime_dependency 'rack-ssl-enforcer'
         | 
| 31 31 | 
             
              spec.add_runtime_dependency 'octokit'
         | 
| 32 | 
            -
              spec.add_runtime_dependency ' | 
| 33 | 
            -
              spec.add_runtime_dependency 'sidekiq'
         | 
| 32 | 
            +
              spec.add_runtime_dependency 'sidekiq', '< 6.0.0'
         | 
| 34 33 | 
             
              spec.add_runtime_dependency 'dogstatsd-ruby'
         | 
| 35 34 | 
             
              spec.add_runtime_dependency 'omniauth-google-oauth2'
         | 
| 36 35 | 
             
              spec.add_runtime_dependency 'faraday'
         | 
| 37 36 | 
             
              spec.add_runtime_dependency 'faraday_middleware'
         | 
| 38 | 
            -
              spec.add_runtime_dependency 'routemaster-client'
         | 
| 39 37 | 
             
              spec.add_runtime_dependency 'json-jwt', '~> 1.8'
         | 
| 40 38 |  | 
| 41 | 
            -
              spec.add_development_dependency 'bundler' | 
| 39 | 
            +
              spec.add_development_dependency 'bundler'
         | 
| 42 40 | 
             
              spec.add_development_dependency 'rake', '~> 10.0'
         | 
| 43 41 | 
             
              spec.add_development_dependency 'rspec', '~> 3.0'
         | 
| 44 42 | 
             
              spec.add_development_dependency 'thor', '~> 0.19'
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: roo_on_rails
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1. | 
| 4 | 
            +
              version: 2.1.2
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Julien Letessier
         | 
| 8 | 
            -
            autorequire: | 
| 8 | 
            +
            autorequire:
         | 
| 9 9 | 
             
            bindir: exe
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2021-06-01 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: dotenv-rails
         | 
| @@ -25,39 +25,33 @@ dependencies: | |
| 25 25 | 
             
                  - !ruby/object:Gem::Version
         | 
| 26 26 | 
             
                    version: '2.1'
         | 
| 27 27 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 28 | 
            -
              name:  | 
| 28 | 
            +
              name: rails
         | 
| 29 29 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 30 30 | 
             
                requirements:
         | 
| 31 31 | 
             
                - - ">="
         | 
| 32 32 | 
             
                  - !ruby/object:Gem::Version
         | 
| 33 | 
            -
                    version:  | 
| 33 | 
            +
                    version: 3.2.22
         | 
| 34 34 | 
             
              type: :runtime
         | 
| 35 35 | 
             
              prerelease: false
         | 
| 36 36 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 37 37 | 
             
                requirements:
         | 
| 38 38 | 
             
                - - ">="
         | 
| 39 39 | 
             
                  - !ruby/object:Gem::Version
         | 
| 40 | 
            -
                    version:  | 
| 40 | 
            +
                    version: 3.2.22
         | 
| 41 41 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 42 | 
            -
              name:  | 
| 42 | 
            +
              name: sprockets
         | 
| 43 43 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 44 44 | 
             
                requirements:
         | 
| 45 | 
            -
                - - " | 
| 46 | 
            -
                  - !ruby/object:Gem::Version
         | 
| 47 | 
            -
                    version: 3.2.22
         | 
| 48 | 
            -
                - - "<"
         | 
| 45 | 
            +
                - - "~>"
         | 
| 49 46 | 
             
                  - !ruby/object:Gem::Version
         | 
| 50 | 
            -
                    version: ' | 
| 47 | 
            +
                    version: '3.0'
         | 
| 51 48 | 
             
              type: :runtime
         | 
| 52 49 | 
             
              prerelease: false
         | 
| 53 50 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 54 51 | 
             
                requirements:
         | 
| 55 | 
            -
                - - " | 
| 56 | 
            -
                  - !ruby/object:Gem::Version
         | 
| 57 | 
            -
                    version: 3.2.22
         | 
| 58 | 
            -
                - - "<"
         | 
| 52 | 
            +
                - - "~>"
         | 
| 59 53 | 
             
                  - !ruby/object:Gem::Version
         | 
| 60 | 
            -
                    version: ' | 
| 54 | 
            +
                    version: '3.0'
         | 
| 61 55 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 62 56 | 
             
              name: platform-api
         | 
| 63 57 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -128,34 +122,20 @@ dependencies: | |
| 128 122 | 
             
                - - ">="
         | 
| 129 123 | 
             
                  - !ruby/object:Gem::Version
         | 
| 130 124 | 
             
                    version: '0'
         | 
| 131 | 
            -
            - !ruby/object:Gem::Dependency
         | 
| 132 | 
            -
              name: hirefire-resource
         | 
| 133 | 
            -
              requirement: !ruby/object:Gem::Requirement
         | 
| 134 | 
            -
                requirements:
         | 
| 135 | 
            -
                - - ">="
         | 
| 136 | 
            -
                  - !ruby/object:Gem::Version
         | 
| 137 | 
            -
                    version: '0'
         | 
| 138 | 
            -
              type: :runtime
         | 
| 139 | 
            -
              prerelease: false
         | 
| 140 | 
            -
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 141 | 
            -
                requirements:
         | 
| 142 | 
            -
                - - ">="
         | 
| 143 | 
            -
                  - !ruby/object:Gem::Version
         | 
| 144 | 
            -
                    version: '0'
         | 
| 145 125 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 146 126 | 
             
              name: sidekiq
         | 
| 147 127 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 148 128 | 
             
                requirements:
         | 
| 149 | 
            -
                - - " | 
| 129 | 
            +
                - - "<"
         | 
| 150 130 | 
             
                  - !ruby/object:Gem::Version
         | 
| 151 | 
            -
                    version:  | 
| 131 | 
            +
                    version: 6.0.0
         | 
| 152 132 | 
             
              type: :runtime
         | 
| 153 133 | 
             
              prerelease: false
         | 
| 154 134 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 155 135 | 
             
                requirements:
         | 
| 156 | 
            -
                - - " | 
| 136 | 
            +
                - - "<"
         | 
| 157 137 | 
             
                  - !ruby/object:Gem::Version
         | 
| 158 | 
            -
                    version:  | 
| 138 | 
            +
                    version: 6.0.0
         | 
| 159 139 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 160 140 | 
             
              name: dogstatsd-ruby
         | 
| 161 141 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -212,20 +192,6 @@ dependencies: | |
| 212 192 | 
             
                - - ">="
         | 
| 213 193 | 
             
                  - !ruby/object:Gem::Version
         | 
| 214 194 | 
             
                    version: '0'
         | 
| 215 | 
            -
            - !ruby/object:Gem::Dependency
         | 
| 216 | 
            -
              name: routemaster-client
         | 
| 217 | 
            -
              requirement: !ruby/object:Gem::Requirement
         | 
| 218 | 
            -
                requirements:
         | 
| 219 | 
            -
                - - ">="
         | 
| 220 | 
            -
                  - !ruby/object:Gem::Version
         | 
| 221 | 
            -
                    version: '0'
         | 
| 222 | 
            -
              type: :runtime
         | 
| 223 | 
            -
              prerelease: false
         | 
| 224 | 
            -
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 225 | 
            -
                requirements:
         | 
| 226 | 
            -
                - - ">="
         | 
| 227 | 
            -
                  - !ruby/object:Gem::Version
         | 
| 228 | 
            -
                    version: '0'
         | 
| 229 195 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 230 196 | 
             
              name: json-jwt
         | 
| 231 197 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -244,16 +210,16 @@ dependencies: | |
| 244 210 | 
             
              name: bundler
         | 
| 245 211 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 246 212 | 
             
                requirements:
         | 
| 247 | 
            -
                - - " | 
| 213 | 
            +
                - - ">="
         | 
| 248 214 | 
             
                  - !ruby/object:Gem::Version
         | 
| 249 | 
            -
                    version: ' | 
| 215 | 
            +
                    version: '0'
         | 
| 250 216 | 
             
              type: :development
         | 
| 251 217 | 
             
              prerelease: false
         | 
| 252 218 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 253 219 | 
             
                requirements:
         | 
| 254 | 
            -
                - - " | 
| 220 | 
            +
                - - ">="
         | 
| 255 221 | 
             
                  - !ruby/object:Gem::Version
         | 
| 256 | 
            -
                    version: ' | 
| 222 | 
            +
                    version: '0'
         | 
| 257 223 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 258 224 | 
             
              name: rake
         | 
| 259 225 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -396,7 +362,6 @@ files: | |
| 396 362 | 
             
            - ".rspec"
         | 
| 397 363 | 
             
            - ".rubocop.yml"
         | 
| 398 364 | 
             
            - ".ruby-version"
         | 
| 399 | 
            -
            - ".travis.yml"
         | 
| 400 365 | 
             
            - Appraisals
         | 
| 401 366 | 
             
            - CHANGELOG.md
         | 
| 402 367 | 
             
            - CONTRIBUTING.md
         | 
| @@ -405,18 +370,17 @@ files: | |
| 405 370 | 
             
            - LICENSE.txt
         | 
| 406 371 | 
             
            - README.google_oauth2.md
         | 
| 407 372 | 
             
            - README.md
         | 
| 408 | 
            -
            - README.routemaster_client.md
         | 
| 409 373 | 
             
            - Rakefile
         | 
| 410 374 | 
             
            - appraise
         | 
| 411 375 | 
             
            - bin/console
         | 
| 412 376 | 
             
            - bin/setup
         | 
| 413 377 | 
             
            - exe/roo_on_rails
         | 
| 414 378 | 
             
            - gemfiles/.bundle/config
         | 
| 415 | 
            -
            - gemfiles/rails_3.gemfile
         | 
| 416 379 | 
             
            - gemfiles/rails_4.gemfile
         | 
| 417 380 | 
             
            - gemfiles/rails_5.gemfile
         | 
| 418 381 | 
             
            - gemfiles/rails_5_1.gemfile
         | 
| 419 382 | 
             
            - gemfiles/rails_5_2.gemfile
         | 
| 383 | 
            +
            - gemfiles/rails_6.gemfile
         | 
| 420 384 | 
             
            - lib/roo_on_rails.rb
         | 
| 421 385 | 
             
            - lib/roo_on_rails/checks.rb
         | 
| 422 386 | 
             
            - lib/roo_on_rails/checks/base.rb
         | 
| @@ -460,16 +424,9 @@ files: | |
| 460 424 | 
             
            - lib/roo_on_rails/railties/env.rb
         | 
| 461 425 | 
             
            - lib/roo_on_rails/railties/google_oauth.rb
         | 
| 462 426 | 
             
            - lib/roo_on_rails/railties/http.rb
         | 
| 463 | 
            -
            - lib/roo_on_rails/railties/logging.rb
         | 
| 464 | 
            -
            - lib/roo_on_rails/railties/new_relic.rb
         | 
| 465 427 | 
             
            - lib/roo_on_rails/railties/rake_tasks.rb
         | 
| 466 428 | 
             
            - lib/roo_on_rails/railties/roo_identity.rb
         | 
| 467 | 
            -
            - lib/roo_on_rails/railties/routemaster.rb
         | 
| 468 429 | 
             
            - lib/roo_on_rails/railties/sidekiq_integration.rb
         | 
| 469 | 
            -
            - lib/roo_on_rails/routemaster/lifecycle_events.rb
         | 
| 470 | 
            -
            - lib/roo_on_rails/routemaster/publish_lifecycle_events.rb
         | 
| 471 | 
            -
            - lib/roo_on_rails/routemaster/publisher.rb
         | 
| 472 | 
            -
            - lib/roo_on_rails/routemaster/publishers.rb
         | 
| 473 430 | 
             
            - lib/roo_on_rails/shell.rb
         | 
| 474 431 | 
             
            - lib/roo_on_rails/sidekiq/loader.rb
         | 
| 475 432 | 
             
            - lib/roo_on_rails/sidekiq/metrics_worker.rb
         | 
| @@ -479,14 +436,13 @@ files: | |
| 479 436 | 
             
            - lib/roo_on_rails/sidekiq/sla_metric.rb
         | 
| 480 437 | 
             
            - lib/roo_on_rails/statsd.rb
         | 
| 481 438 | 
             
            - lib/roo_on_rails/tasks/db.rake
         | 
| 482 | 
            -
            - lib/roo_on_rails/tasks/newrelic.rake
         | 
| 483 439 | 
             
            - lib/roo_on_rails/version.rb
         | 
| 484 440 | 
             
            - roo_on_rails.gemspec
         | 
| 485 441 | 
             
            homepage: https://github.com/deliveroo/roo_on_rails
         | 
| 486 442 | 
             
            licenses:
         | 
| 487 443 | 
             
            - MIT
         | 
| 488 444 | 
             
            metadata: {}
         | 
| 489 | 
            -
            post_install_message: | 
| 445 | 
            +
            post_install_message:
         | 
| 490 446 | 
             
            rdoc_options: []
         | 
| 491 447 | 
             
            require_paths:
         | 
| 492 448 | 
             
            - lib
         | 
| @@ -501,9 +457,9 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 501 457 | 
             
                - !ruby/object:Gem::Version
         | 
| 502 458 | 
             
                  version: '0'
         | 
| 503 459 | 
             
            requirements: []
         | 
| 504 | 
            -
            rubyforge_project: | 
| 505 | 
            -
            rubygems_version: 2. | 
| 506 | 
            -
            signing_key: | 
| 460 | 
            +
            rubyforge_project:
         | 
| 461 | 
            +
            rubygems_version: 2.6.11
         | 
| 462 | 
            +
            signing_key:
         | 
| 507 463 | 
             
            specification_version: 4
         | 
| 508 464 | 
             
            summary: Scaffolding for building services
         | 
| 509 465 | 
             
            test_files: []
         |