health_monitor_lb 1.0.0

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.
Files changed (66) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +78 -0
  3. data/Rakefile +8 -0
  4. data/app/controllers/health_monitor/application_controller.rb +11 -0
  5. data/app/controllers/health_monitor/health_controller.rb +13 -0
  6. data/app/services/health_monitor/health_check_service.rb +40 -0
  7. data/bin/rails +14 -0
  8. data/config/routes.rb +3 -0
  9. data/lib/health_monitor/engine.rb +5 -0
  10. data/lib/health_monitor/version.rb +3 -0
  11. data/lib/health_monitor.rb +11 -0
  12. data/lib/tasks/health_monitor_tasks.rake +4 -0
  13. data/spec/controllers/health_monitor/health_controller_spec.rb +40 -0
  14. data/spec/dummy/Rakefile +6 -0
  15. data/spec/dummy/app/assets/config/manifest.js +3 -0
  16. data/spec/dummy/app/assets/stylesheets/application.css +15 -0
  17. data/spec/dummy/app/channels/application_cable/channel.rb +4 -0
  18. data/spec/dummy/app/channels/application_cable/connection.rb +4 -0
  19. data/spec/dummy/app/controllers/application_controller.rb +2 -0
  20. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  21. data/spec/dummy/app/javascript/packs/application.js +15 -0
  22. data/spec/dummy/app/jobs/application_job.rb +7 -0
  23. data/spec/dummy/app/mailers/application_mailer.rb +4 -0
  24. data/spec/dummy/app/models/application_record.rb +3 -0
  25. data/spec/dummy/app/views/layouts/application.html.erb +15 -0
  26. data/spec/dummy/app/views/layouts/mailer.html.erb +13 -0
  27. data/spec/dummy/app/views/layouts/mailer.text.erb +1 -0
  28. data/spec/dummy/bin/rails +4 -0
  29. data/spec/dummy/bin/rake +4 -0
  30. data/spec/dummy/bin/setup +33 -0
  31. data/spec/dummy/config/application.rb +22 -0
  32. data/spec/dummy/config/boot.rb +5 -0
  33. data/spec/dummy/config/cable.yml +10 -0
  34. data/spec/dummy/config/database.yml +2 -0
  35. data/spec/dummy/config/environment.rb +5 -0
  36. data/spec/dummy/config/environments/development.rb +76 -0
  37. data/spec/dummy/config/environments/production.rb +120 -0
  38. data/spec/dummy/config/environments/test.rb +59 -0
  39. data/spec/dummy/config/initializers/application_controller_renderer.rb +8 -0
  40. data/spec/dummy/config/initializers/assets.rb +12 -0
  41. data/spec/dummy/config/initializers/backtrace_silencers.rb +8 -0
  42. data/spec/dummy/config/initializers/content_security_policy.rb +28 -0
  43. data/spec/dummy/config/initializers/cookies_serializer.rb +5 -0
  44. data/spec/dummy/config/initializers/filter_parameter_logging.rb +6 -0
  45. data/spec/dummy/config/initializers/inflections.rb +16 -0
  46. data/spec/dummy/config/initializers/mime_types.rb +4 -0
  47. data/spec/dummy/config/initializers/permissions_policy.rb +11 -0
  48. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  49. data/spec/dummy/config/locales/en.yml +33 -0
  50. data/spec/dummy/config/puma.rb +43 -0
  51. data/spec/dummy/config/routes.rb +3 -0
  52. data/spec/dummy/config/storage.yml +34 -0
  53. data/spec/dummy/config.ru +6 -0
  54. data/spec/dummy/log/development.log +0 -0
  55. data/spec/dummy/log/test.log +184 -0
  56. data/spec/dummy/public/404.html +67 -0
  57. data/spec/dummy/public/422.html +67 -0
  58. data/spec/dummy/public/500.html +66 -0
  59. data/spec/dummy/public/apple-touch-icon-precomposed.png +0 -0
  60. data/spec/dummy/public/apple-touch-icon.png +0 -0
  61. data/spec/dummy/public/favicon.ico +0 -0
  62. data/spec/dummy/tmp/development_secret.txt +1 -0
  63. data/spec/health_monitor_spec.rb +8 -0
  64. data/spec/rails_helper.rb +1 -0
  65. data/spec/spec_helper.rb +31 -0
  66. metadata +178 -0
@@ -0,0 +1,120 @@
1
+ require "active_support/core_ext/integer/time"
2
+
3
+ Rails.application.configure do
4
+ # Settings specified here will take precedence over those in config/application.rb.
5
+
6
+ # Code is not reloaded between requests.
7
+ config.cache_classes = true
8
+
9
+ # Eager load code on boot. This eager loads most of Rails and
10
+ # your application in memory, allowing both threaded web servers
11
+ # and those relying on copy on write to perform better.
12
+ # Rake tasks automatically ignore this option for performance.
13
+ config.eager_load = true
14
+
15
+ # Full error reports are disabled and caching is turned on.
16
+ config.consider_all_requests_local = false
17
+ config.action_controller.perform_caching = true
18
+
19
+ # Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"]
20
+ # or in config/master.key. This key is used to decrypt credentials (and other encrypted files).
21
+ # config.require_master_key = true
22
+
23
+ # Disable serving static files from the `/public` folder by default since
24
+ # Apache or NGINX already handles this.
25
+ config.public_file_server.enabled = ENV['RAILS_SERVE_STATIC_FILES'].present?
26
+
27
+ # Compress CSS using a preprocessor.
28
+ # config.assets.css_compressor = :sass
29
+
30
+ # Do not fallback to assets pipeline if a precompiled asset is missed.
31
+ config.assets.compile = false
32
+
33
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server.
34
+ # config.asset_host = 'http://assets.example.com'
35
+
36
+ # Specifies the header that your server uses for sending files.
37
+ # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
38
+ # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
39
+
40
+ # Store uploaded files on the local file system (see config/storage.yml for options).
41
+ config.active_storage.service = :local
42
+
43
+ # Mount Action Cable outside main process or domain.
44
+ # config.action_cable.mount_path = nil
45
+ # config.action_cable.url = 'wss://example.com/cable'
46
+ # config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ]
47
+
48
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
49
+ # config.force_ssl = true
50
+
51
+ # Include generic and useful information about system operation, but avoid logging too much
52
+ # information to avoid inadvertent exposure of personally identifiable information (PII).
53
+ config.log_level = :info
54
+
55
+ # Prepend all log lines with the following tags.
56
+ config.log_tags = [ :request_id ]
57
+
58
+ # Use a different cache store in production.
59
+ # config.cache_store = :mem_cache_store
60
+
61
+ # Use a real queuing backend for Active Job (and separate queues per environment).
62
+ # config.active_job.queue_adapter = :resque
63
+ # config.active_job.queue_name_prefix = "dummy_production"
64
+
65
+ config.action_mailer.perform_caching = false
66
+
67
+ # Ignore bad email addresses and do not raise email delivery errors.
68
+ # Set this to true and configure the email server for immediate delivery to raise delivery errors.
69
+ # config.action_mailer.raise_delivery_errors = false
70
+
71
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
72
+ # the I18n.default_locale when a translation cannot be found).
73
+ config.i18n.fallbacks = true
74
+
75
+ # Send deprecation notices to registered listeners.
76
+ config.active_support.deprecation = :notify
77
+
78
+ # Log disallowed deprecations.
79
+ config.active_support.disallowed_deprecation = :log
80
+
81
+ # Tell Active Support which deprecation messages to disallow.
82
+ config.active_support.disallowed_deprecation_warnings = []
83
+
84
+ # Use default logging formatter so that PID and timestamp are not suppressed.
85
+ config.log_formatter = ::Logger::Formatter.new
86
+
87
+ # Use a different logger for distributed setups.
88
+ # require "syslog/logger"
89
+ # config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name')
90
+
91
+ if ENV["RAILS_LOG_TO_STDOUT"].present?
92
+ logger = ActiveSupport::Logger.new(STDOUT)
93
+ logger.formatter = config.log_formatter
94
+ config.logger = ActiveSupport::TaggedLogging.new(logger)
95
+ end
96
+
97
+ # Do not dump schema after migrations.
98
+ config.active_record.dump_schema_after_migration = false
99
+
100
+ # Inserts middleware to perform automatic connection switching.
101
+ # The `database_selector` hash is used to pass options to the DatabaseSelector
102
+ # middleware. The `delay` is used to determine how long to wait after a write
103
+ # to send a subsequent read to the primary.
104
+ #
105
+ # The `database_resolver` class is used by the middleware to determine which
106
+ # database is appropriate to use based on the time delay.
107
+ #
108
+ # The `database_resolver_context` class is used by the middleware to set
109
+ # timestamps for the last write to the primary. The resolver uses the context
110
+ # class timestamps to determine how long to wait before reading from the
111
+ # replica.
112
+ #
113
+ # By default Rails will store a last write timestamp in the session. The
114
+ # DatabaseSelector middleware is designed as such you can define your own
115
+ # strategy for connection switching and pass that into the middleware through
116
+ # these configuration options.
117
+ # config.active_record.database_selector = { delay: 2.seconds }
118
+ # config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver
119
+ # config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session
120
+ end
@@ -0,0 +1,59 @@
1
+ require "active_support/core_ext/integer/time"
2
+
3
+ # The test environment is used exclusively to run your application's
4
+ # test suite. You never need to work with it otherwise. Remember that
5
+ # your test database is "scratch space" for the test suite and is wiped
6
+ # and recreated between test runs. Don't rely on the data there!
7
+
8
+ Rails.application.configure do
9
+ # Settings specified here will take precedence over those in config/application.rb.
10
+
11
+ config.cache_classes = true
12
+
13
+ # Do not eager load code on boot. This avoids loading your whole application
14
+ # just for the purpose of running a single test. If you are using a tool that
15
+ # preloads Rails for running tests, you may have to set it to true.
16
+ config.eager_load = false
17
+
18
+ # Configure public file server for tests with Cache-Control for performance.
19
+ config.public_file_server.enabled = true
20
+ config.public_file_server.headers = {
21
+ 'Cache-Control' => "public, max-age=#{1.hour.to_i}"
22
+ }
23
+
24
+ # Show full error reports and disable caching.
25
+ config.consider_all_requests_local = true
26
+ config.action_controller.perform_caching = false
27
+ config.cache_store = :null_store
28
+
29
+ # Raise exceptions instead of rendering exception templates.
30
+ config.action_dispatch.show_exceptions = false
31
+
32
+ # Disable request forgery protection in test environment.
33
+ config.action_controller.allow_forgery_protection = false
34
+
35
+ # Store uploaded files on the local file system in a temporary directory.
36
+ config.active_storage.service = :test
37
+
38
+ config.action_mailer.perform_caching = false
39
+
40
+ # Tell Action Mailer not to deliver emails to the real world.
41
+ # The :test delivery method accumulates sent emails in the
42
+ # ActionMailer::Base.deliveries array.
43
+ config.action_mailer.delivery_method = :test
44
+
45
+ # Print deprecation notices to the stderr.
46
+ config.active_support.deprecation = :stderr
47
+
48
+ # Raise exceptions for disallowed deprecations.
49
+ config.active_support.disallowed_deprecation = :raise
50
+
51
+ # Tell Active Support which deprecation messages to disallow.
52
+ config.active_support.disallowed_deprecation_warnings = []
53
+
54
+ # Raises error for missing translations.
55
+ # config.i18n.raise_on_missing_translations = true
56
+
57
+ # Annotate rendered view with file names.
58
+ # config.action_view.annotate_rendered_view_with_filenames = true
59
+ end
@@ -0,0 +1,8 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # ActiveSupport::Reloader.to_prepare do
4
+ # ApplicationController.renderer.defaults.merge!(
5
+ # http_host: 'example.org',
6
+ # https: false
7
+ # )
8
+ # end
@@ -0,0 +1,12 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Version of your assets, change this if you want to expire all your assets.
4
+ Rails.application.config.assets.version = '1.0'
5
+
6
+ # Add additional assets to the asset load path.
7
+ # Rails.application.config.assets.paths << Emoji.images_path
8
+
9
+ # Precompile additional assets.
10
+ # application.js, application.css, and all non-JS/CSS in the app/assets
11
+ # folder are already added.
12
+ # Rails.application.config.assets.precompile += %w( admin.js admin.css )
@@ -0,0 +1,8 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4
+ # Rails.backtrace_cleaner.add_silencer { |line| /my_noisy_library/.match?(line) }
5
+
6
+ # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code
7
+ # by setting BACKTRACE=1 before calling your invocation, like "BACKTRACE=1 ./bin/rails runner 'MyClass.perform'".
8
+ Rails.backtrace_cleaner.remove_silencers! if ENV["BACKTRACE"]
@@ -0,0 +1,28 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Define an application-wide content security policy
4
+ # For further information see the following documentation
5
+ # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy
6
+
7
+ # Rails.application.config.content_security_policy do |policy|
8
+ # policy.default_src :self, :https
9
+ # policy.font_src :self, :https, :data
10
+ # policy.img_src :self, :https, :data
11
+ # policy.object_src :none
12
+ # policy.script_src :self, :https
13
+ # policy.style_src :self, :https
14
+
15
+ # # Specify URI for violation reports
16
+ # # policy.report_uri "/csp-violation-report-endpoint"
17
+ # end
18
+
19
+ # If you are using UJS then enable automatic nonce generation
20
+ # Rails.application.config.content_security_policy_nonce_generator = -> request { SecureRandom.base64(16) }
21
+
22
+ # Set the nonce only to specific directives
23
+ # Rails.application.config.content_security_policy_nonce_directives = %w(script-src)
24
+
25
+ # Report CSP violations to a specified URI
26
+ # For further information see the following documentation:
27
+ # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy-Report-Only
28
+ # Rails.application.config.content_security_policy_report_only = true
@@ -0,0 +1,5 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Specify a serializer for the signed and encrypted cookie jars.
4
+ # Valid options are :json, :marshal, and :hybrid.
5
+ Rails.application.config.action_dispatch.cookies_serializer = :json
@@ -0,0 +1,6 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Configure sensitive parameters which will be filtered from the log file.
4
+ Rails.application.config.filter_parameters += [
5
+ :passw, :secret, :token, :_key, :crypt, :salt, :certificate, :otp, :ssn
6
+ ]
@@ -0,0 +1,16 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new inflection rules using the following format. Inflections
4
+ # are locale specific, and you may define rules for as many different
5
+ # locales as you wish. All of these examples are active by default:
6
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
7
+ # inflect.plural /^(ox)$/i, '\1en'
8
+ # inflect.singular /^(ox)en/i, '\1'
9
+ # inflect.irregular 'person', 'people'
10
+ # inflect.uncountable %w( fish sheep )
11
+ # end
12
+
13
+ # These inflection rules are supported but not enabled by default:
14
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
15
+ # inflect.acronym 'RESTful'
16
+ # end
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new mime types for use in respond_to blocks:
4
+ # Mime::Type.register "text/richtext", :rtf
@@ -0,0 +1,11 @@
1
+ # Define an application-wide HTTP permissions policy. For further
2
+ # information see https://developers.google.com/web/updates/2018/06/feature-policy
3
+ #
4
+ # Rails.application.config.permissions_policy do |f|
5
+ # f.camera :none
6
+ # f.gyroscope :none
7
+ # f.microphone :none
8
+ # f.usb :none
9
+ # f.fullscreen :self
10
+ # f.payment :self, "https://secure.example.com"
11
+ # end
@@ -0,0 +1,14 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # This file contains settings for ActionController::ParamsWrapper which
4
+ # is enabled by default.
5
+
6
+ # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7
+ ActiveSupport.on_load(:action_controller) do
8
+ wrap_parameters format: [:json]
9
+ end
10
+
11
+ # To enable root element in JSON for ActiveRecord objects.
12
+ # ActiveSupport.on_load(:active_record) do
13
+ # self.include_root_in_json = true
14
+ # end
@@ -0,0 +1,33 @@
1
+ # Files in the config/locales directory are used for internationalization
2
+ # and are automatically loaded by Rails. If you want to use locales other
3
+ # than English, add the necessary files in this directory.
4
+ #
5
+ # To use the locales, use `I18n.t`:
6
+ #
7
+ # I18n.t 'hello'
8
+ #
9
+ # In views, this is aliased to just `t`:
10
+ #
11
+ # <%= t('hello') %>
12
+ #
13
+ # To use a different locale, set it with `I18n.locale`:
14
+ #
15
+ # I18n.locale = :es
16
+ #
17
+ # This would use the information in config/locales/es.yml.
18
+ #
19
+ # The following keys must be escaped otherwise they will not be retrieved by
20
+ # the default I18n backend:
21
+ #
22
+ # true, false, on, off, yes, no
23
+ #
24
+ # Instead, surround them with single quotes.
25
+ #
26
+ # en:
27
+ # 'true': 'foo'
28
+ #
29
+ # To learn more, please read the Rails Internationalization guide
30
+ # available at https://guides.rubyonrails.org/i18n.html.
31
+
32
+ en:
33
+ hello: "Hello world"
@@ -0,0 +1,43 @@
1
+ # Puma can serve each request in a thread from an internal thread pool.
2
+ # The `threads` method setting takes two numbers: a minimum and maximum.
3
+ # Any libraries that use thread pools should be configured to match
4
+ # the maximum value specified for Puma. Default is set to 5 threads for minimum
5
+ # and maximum; this matches the default thread size of Active Record.
6
+ #
7
+ max_threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }
8
+ min_threads_count = ENV.fetch("RAILS_MIN_THREADS") { max_threads_count }
9
+ threads min_threads_count, max_threads_count
10
+
11
+ # Specifies the `worker_timeout` threshold that Puma will use to wait before
12
+ # terminating a worker in development environments.
13
+ #
14
+ worker_timeout 3600 if ENV.fetch("RAILS_ENV", "development") == "development"
15
+
16
+ # Specifies the `port` that Puma will listen on to receive requests; default is 3000.
17
+ #
18
+ port ENV.fetch("PORT") { 3000 }
19
+
20
+ # Specifies the `environment` that Puma will run in.
21
+ #
22
+ environment ENV.fetch("RAILS_ENV") { "development" }
23
+
24
+ # Specifies the `pidfile` that Puma will use.
25
+ pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" }
26
+
27
+ # Specifies the number of `workers` to boot in clustered mode.
28
+ # Workers are forked web server processes. If using threads and workers together
29
+ # the concurrency of the application would be max `threads` * `workers`.
30
+ # Workers do not work on JRuby or Windows (both of which do not support
31
+ # processes).
32
+ #
33
+ # workers ENV.fetch("WEB_CONCURRENCY") { 2 }
34
+
35
+ # Use the `preload_app!` method when specifying a `workers` number.
36
+ # This directive tells Puma to first boot the application and load code
37
+ # before forking the application. This takes advantage of Copy On Write
38
+ # process behavior so workers use less memory.
39
+ #
40
+ # preload_app!
41
+
42
+ # Allow puma to be restarted by `rails restart` command.
43
+ plugin :tmp_restart
@@ -0,0 +1,3 @@
1
+ Rails.application.routes.draw do
2
+ mount HealthMonitor::Engine => '/'
3
+ end
@@ -0,0 +1,34 @@
1
+ test:
2
+ service: Disk
3
+ root: <%= Rails.root.join("tmp/storage") %>
4
+
5
+ local:
6
+ service: Disk
7
+ root: <%= Rails.root.join("storage") %>
8
+
9
+ # Use rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key)
10
+ # amazon:
11
+ # service: S3
12
+ # access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
13
+ # secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
14
+ # region: us-east-1
15
+ # bucket: your_own_bucket
16
+
17
+ # Remember not to checkin your GCS keyfile to a repository
18
+ # google:
19
+ # service: GCS
20
+ # project: your_project
21
+ # credentials: <%= Rails.root.join("path/to/gcs.keyfile") %>
22
+ # bucket: your_own_bucket
23
+
24
+ # Use rails credentials:edit to set the Azure Storage secret (as azure_storage:storage_access_key)
25
+ # microsoft:
26
+ # service: AzureStorage
27
+ # storage_account_name: your_account_name
28
+ # storage_access_key: <%= Rails.application.credentials.dig(:azure_storage, :storage_access_key) %>
29
+ # container: your_container_name
30
+
31
+ # mirror:
32
+ # service: Mirror
33
+ # primary: local
34
+ # mirrors: [ amazon, google, microsoft ]
@@ -0,0 +1,6 @@
1
+ # This file is used by Rack-based servers to start the application.
2
+
3
+ require_relative "config/environment"
4
+
5
+ run Rails.application
6
+ Rails.application.load_server
File without changes
@@ -0,0 +1,184 @@
1
+ Processing by HealthMonitor::HealthController#index as HTML
2
+ Filter chain halted as :check_api_token rendered or redirected
3
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
4
+ Processing by HealthMonitor::HealthController#index as HTML
5
+ Filter chain halted as :check_api_token rendered or redirected
6
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
7
+ Processing by HealthMonitor::HealthController#index as HTML
8
+ Filter chain halted as :check_api_token rendered or redirected
9
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 107)
10
+ Processing by HealthMonitor::HealthController#index as HTML
11
+ Filter chain halted as :check_api_token rendered or redirected
12
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
13
+ Processing by HealthMonitor::HealthController#index as HTML
14
+ Filter chain halted as :check_api_token rendered or redirected
15
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 107)
16
+ Processing by HealthMonitor::HealthController#index as HTML
17
+ Filter chain halted as :check_api_token rendered or redirected
18
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
19
+ Processing by HealthMonitor::HealthController#index as HTML
20
+ Filter chain halted as :check_api_token rendered or redirected
21
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 107)
22
+ Processing by HealthMonitor::HealthController#index as HTML
23
+ Filter chain halted as :check_api_token rendered or redirected
24
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
25
+ Processing by HealthMonitor::HealthController#index as HTML
26
+ Filter chain halted as :check_api_token rendered or redirected
27
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 107)
28
+ Processing by HealthMonitor::HealthController#index as HTML
29
+ Filter chain halted as :check_api_token rendered or redirected
30
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
31
+ Processing by HealthMonitor::HealthController#index as HTML
32
+ Filter chain halted as :check_api_token rendered or redirected
33
+ Completed 401 Unauthorized in 0ms (Views: 0.0ms | ActiveRecord: 0.0ms | Allocations: 106)
34
+ Processing by HealthMonitor::HealthController#index as HTML
35
+ Filter chain halted as :check_api_token rendered or redirected
36
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
37
+ Processing by HealthMonitor::HealthController#index as HTML
38
+ Completed 200 OK in 121ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 369)
39
+ Processing by HealthMonitor::HealthController#index as HTML
40
+ Filter chain halted as :check_api_token rendered or redirected
41
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
42
+ Processing by HealthMonitor::HealthController#index as HTML
43
+ Completed 200 OK in 103ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 370)
44
+ Processing by HealthMonitor::HealthController#index as HTML
45
+ Filter chain halted as :check_api_token rendered or redirected
46
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
47
+ Processing by HealthMonitor::HealthController#index as HTML
48
+ Completed 200 OK in 99ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 370)
49
+ Processing by HealthMonitor::HealthController#index as HTML
50
+ Filter chain halted as :check_api_token rendered or redirected
51
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
52
+ Processing by HealthMonitor::HealthController#index as HTML
53
+ Completed 200 OK in 109ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 369)
54
+ Processing by HealthMonitor::HealthController#index as HTML
55
+ Filter chain halted as :check_api_token rendered or redirected
56
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
57
+ Processing by HealthMonitor::HealthController#index as HTML
58
+ Completed 200 OK in 105ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 369)
59
+ Processing by HealthMonitor::HealthController#index as HTML
60
+ Filter chain halted as :check_api_token rendered or redirected
61
+ Completed 401 Unauthorized in 1ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 267)
62
+ Processing by HealthMonitor::HealthController#index as HTML
63
+ Completed 200 OK in 110ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 368)
64
+ Processing by HealthMonitor::HealthController#index as HTML
65
+ Filter chain halted as :check_api_token rendered or redirected
66
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
67
+ Processing by HealthMonitor::HealthController#index as HTML
68
+ Completed 200 OK in 102ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 368)
69
+ Processing by HealthMonitor::HealthController#index as HTML
70
+ Filter chain halted as :check_api_token rendered or redirected
71
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
72
+ Processing by HealthMonitor::HealthController#index as HTML
73
+ Completed 200 OK in 99ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 367)
74
+ Processing by HealthMonitor::HealthController#index as HTML
75
+ Filter chain halted as :check_api_token rendered or redirected
76
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
77
+ Processing by HealthMonitor::HealthController#index as HTML
78
+ Completed 200 OK in 100ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 367)
79
+ Processing by HealthMonitor::HealthController#index as HTML
80
+ Filter chain halted as :check_api_token rendered or redirected
81
+ Completed 401 Unauthorized in 1ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
82
+ Processing by HealthMonitor::HealthController#index as HTML
83
+ Completed 200 OK in 100ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 368)
84
+ Processing by HealthMonitor::HealthController#index as HTML
85
+ Filter chain halted as :check_api_token rendered or redirected
86
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
87
+ Processing by HealthMonitor::HealthController#index as HTML
88
+ Completed 200 OK in 95ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 367)
89
+ Processing by HealthMonitor::HealthController#index as HTML
90
+ Filter chain halted as :check_api_token rendered or redirected
91
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
92
+ Processing by HealthMonitor::HealthController#index as HTML
93
+ Completed 200 OK in 99ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 368)
94
+ Processing by HealthMonitor::HealthController#index as HTML
95
+ Filter chain halted as :check_api_token rendered or redirected
96
+ Completed 401 Unauthorized in 1ms (Views: 0.3ms | ActiveRecord: 0.0ms | Allocations: 267)
97
+ Processing by HealthMonitor::HealthController#index as HTML
98
+ Completed 200 OK in 101ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 369)
99
+ Processing by HealthMonitor::HealthController#index as HTML
100
+ Filter chain halted as :check_api_token rendered or redirected
101
+ Completed 401 Unauthorized in 1ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 267)
102
+ Processing by HealthMonitor::HealthController#index as HTML
103
+ Completed 200 OK in 103ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 368)
104
+ Processing by HealthMonitor::HealthController#index as HTML
105
+ Completed 500 Internal Server Error in 100ms (ActiveRecord: 0.0ms | Allocations: 175)
106
+ Processing by HealthMonitor::HealthController#index as HTML
107
+ Filter chain halted as :check_api_token rendered or redirected
108
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 267)
109
+ Processing by HealthMonitor::HealthController#index as HTML
110
+ Completed 200 OK in 93ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 367)
111
+ Processing by HealthMonitor::HealthController#index as HTML
112
+ Completed 200 OK in 91ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 167)
113
+ Processing by HealthMonitor::HealthController#index as HTML
114
+ Filter chain halted as :check_api_token rendered or redirected
115
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 282)
116
+ Processing by HealthMonitor::HealthController#index as HTML
117
+ Filter chain halted as :check_api_token rendered or redirected
118
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 117)
119
+ Processing by HealthMonitor::HealthController#index as HTML
120
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
121
+ Completed 200 OK in 108ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 405)
122
+ Processing by HealthMonitor::HealthController#index as HTML
123
+ Filter chain halted as :check_api_token rendered or redirected
124
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 290)
125
+ Processing by HealthMonitor::HealthController#index as HTML
126
+ Filter chain halted as :check_api_token rendered or redirected
127
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 123)
128
+ Processing by HealthMonitor::HealthController#index as HTML
129
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
130
+ Completed 200 OK in 103ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 409)
131
+ Processing by HealthMonitor::HealthController#index as HTML
132
+ Filter chain halted as :check_api_token rendered or redirected
133
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 293)
134
+ Processing by HealthMonitor::HealthController#index as HTML
135
+ Filter chain halted as :check_api_token rendered or redirected
136
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 123)
137
+ Processing by HealthMonitor::HealthController#index as HTML
138
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
139
+ Completed 200 OK in 102ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 409)
140
+ Processing by HealthMonitor::HealthController#index as HTML
141
+ Filter chain halted as :check_api_token rendered or redirected
142
+ Completed 401 Unauthorized in 1ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 291)
143
+ Processing by HealthMonitor::HealthController#index as HTML
144
+ Filter chain halted as :check_api_token rendered or redirected
145
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 122)
146
+ Processing by HealthMonitor::HealthController#index as HTML
147
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
148
+ Completed 200 OK in 113ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 410)
149
+ Processing by HealthMonitor::HealthController#index as HTML
150
+ Filter chain halted as :check_api_token rendered or redirected
151
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 295)
152
+ Processing by HealthMonitor::HealthController#index as HTML
153
+ Filter chain halted as :check_api_token rendered or redirected
154
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 126)
155
+ Processing by HealthMonitor::HealthController#index as HTML
156
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
157
+ Completed 200 OK in 93ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 416)
158
+ Processing by HealthMonitor::HealthController#index as HTML
159
+ Filter chain halted as :check_api_token rendered or redirected
160
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 295)
161
+ Processing by HealthMonitor::HealthController#index as HTML
162
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
163
+ Completed 200 OK in 101ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 397)
164
+ Processing by HealthMonitor::HealthController#index as HTML
165
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
166
+ Completed 200 OK in 112ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 195)
167
+ Processing by HealthMonitor::HealthController#index as HTML
168
+ Filter chain halted as :check_api_token rendered or redirected
169
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 290)
170
+ Processing by HealthMonitor::HealthController#index as HTML
171
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
172
+ Completed 200 OK in 93ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 390)
173
+ Processing by HealthMonitor::HealthController#index as HTML
174
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
175
+ Completed 200 OK in 97ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 188)
176
+ Processing by HealthMonitor::HealthController#index as HTML
177
+ Filter chain halted as :check_api_token rendered or redirected
178
+ Completed 401 Unauthorized in 0ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 282)
179
+ Processing by HealthMonitor::HealthController#index as HTML
180
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
181
+ Completed 200 OK in 94ms (Views: 0.2ms | ActiveRecord: 0.0ms | Allocations: 386)
182
+ Processing by HealthMonitor::HealthController#index as HTML
183
+ Parameters: {"API_TOKEN"=>"[FILTERED]"}
184
+ Completed 200 OK in 93ms (Views: 0.1ms | ActiveRecord: 0.0ms | Allocations: 184)