nulogy_message_bus_producer 3.4.0 → 3.7.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +26 -27
- data/lib/nulogy_message_bus_producer/config.rb +1 -1
- data/lib/nulogy_message_bus_producer/self_serve_subscription.rb +18 -0
- data/lib/nulogy_message_bus_producer/subscriptions/configured_subscription.rb +14 -0
- data/lib/nulogy_message_bus_producer/subscriptions/finder.rb +2 -2
- data/lib/nulogy_message_bus_producer/subscriptions/postgres_transport.rb +4 -4
- data/lib/nulogy_message_bus_producer/subscriptions/query_validator.rb +1 -1
- data/lib/nulogy_message_bus_producer/subscriptions/valid_for_schema_validator.rb +14 -0
- data/lib/nulogy_message_bus_producer/version.rb +1 -1
- data/lib/nulogy_message_bus_producer.rb +7 -4
- data/spec/dummy/bin/setup +8 -9
- data/spec/dummy/bin/yarn +15 -7
- data/spec/dummy/config/application.rb +11 -6
- data/spec/dummy/config/boot.rb +2 -4
- data/spec/dummy/config/cable.yml +2 -2
- data/spec/dummy/config/environments/development.rb +29 -7
- data/spec/dummy/config/environments/production.rb +45 -15
- data/spec/dummy/config/environments/test.rb +24 -7
- data/spec/dummy/config/initializers/backtrace_silencers.rb +4 -3
- data/spec/dummy/config/initializers/content_security_policy.rb +30 -0
- data/spec/dummy/config/initializers/filter_parameter_logging.rb +3 -1
- data/spec/dummy/config/initializers/new_framework_defaults_6_1.rb +67 -0
- data/spec/dummy/config/initializers/permissions_policy.rb +11 -0
- data/spec/dummy/config/locales/en.yml +1 -1
- data/spec/dummy/config/storage.yml +34 -0
- data/spec/dummy/config.ru +1 -0
- data/spec/integration/lib/nulogy_message_bus_producer/repopulate_replication_slots_spec.rb +1 -1
- data/spec/integration/lib/nulogy_message_bus_producer/subscription_spec.rb +3 -75
- data/spec/integration_spec_helper.rb +0 -6
- data/spec/nulogy_message_bus_producer/subscriptions/subscription_spec.rb +9 -0
- data/spec/spec_helper.rb +5 -0
- data/spec/support/shared_examples/subscription_validations.rb +77 -0
- data/spec/support/skip.rb +9 -0
- data/spec/support/sql_helpers.rb +1 -1
- data/spec/support/subscription_helpers.rb +2 -2
- data/spec/support/test_graphql_schema.rb +0 -2
- metadata +110 -64
- data/lib/nulogy_message_bus_producer/subscription.rb +0 -30
- data/spec/dummy/log/development.log +0 -2333
- data/spec/dummy/log/test.log +0 -44636
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 03f3807e1992d52e065a17dc00d3fa2b3bc7b2fc3fe85ad938f6374030dbc6fb
|
4
|
+
data.tar.gz: eae26df87208bb6744aabf0f0cadf22f7fe3e911adefd75954af3c7455931451
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 622fd9b24890ceea7604a6b5beb7e9847d72a0d65ebed031e287b752ca917f9692f9e9365fea9b59340e17642e612099fa9d2106f182317904b5650e769552d4
|
7
|
+
data.tar.gz: 67c696faec09c095ae494371221262c81c8c2bccb0cd4e59bf93c10aabcc05dcec44e189ba081e9b330fdc868da3295f66b396e6a0d505be1bd2c1de743e12a0
|
data/README.md
CHANGED
@@ -8,6 +8,7 @@ This engine contains the classes and validations for producing messages to the M
|
|
8
8
|
|
9
9
|
1. Add the gem to your Gemfile: `gem "nulogy_message_bus_producer"`
|
10
10
|
2. Install the migrations: `rake railties:install:migrations`
|
11
|
+
3. Use the [Nulogy GraphQL API](https://github.com/nulogy/nulogy_graphql_api)'s schema specs to [ensure schema changes are safe](https://github.com/nulogy/nulogy_graphql_api#schema-generation)
|
11
12
|
|
12
13
|
## Usage
|
13
14
|
|
@@ -24,26 +25,7 @@ Debezium then reads this table from the PG replication log and pushes them into
|
|
24
25
|
|
25
26
|
There are two ways to create subscriptions:
|
26
27
|
|
27
|
-
####
|
28
|
-
|
29
|
-
You create these subscriptions via the public GraphQL API. e.g.
|
30
|
-
|
31
|
-
```graphql
|
32
|
-
subscription {
|
33
|
-
workOrderUpdated(subscriptionId: "uuid", subscriptionGroupId: "uuid", topicName: "some-topic") {
|
34
|
-
workOrder {
|
35
|
-
id
|
36
|
-
code
|
37
|
-
}
|
38
|
-
}
|
39
|
-
}
|
40
|
-
```
|
41
|
-
|
42
|
-
These subscriptions are written to the `NulogyMessageBusProducer.subscriptions_table_name` table.
|
43
|
-
|
44
|
-
This style of subscriptions may be removed in a future release.
|
45
|
-
|
46
|
-
#### Configured (new)
|
28
|
+
#### Configured
|
47
29
|
|
48
30
|
Subscriptions provided by configuration in the producer app:
|
49
31
|
|
@@ -66,13 +48,35 @@ NulogyMessageBusProducer.configure do |c|
|
|
66
48
|
end
|
67
49
|
```
|
68
50
|
|
51
|
+
#### Self-Serve (soft-deprecated)
|
52
|
+
|
53
|
+
You create these subscriptions via the public GraphQL API. For testing, the [Insomnia](https://insomnia.rest/) client
|
54
|
+
is highly recommended.
|
55
|
+
|
56
|
+
```graphql
|
57
|
+
subscription {
|
58
|
+
workOrderUpdated(subscriptionId: "uuid", subscriptionGroupId: "uuid", topicName: "some-topic") {
|
59
|
+
workOrder {
|
60
|
+
id
|
61
|
+
code
|
62
|
+
}
|
63
|
+
}
|
64
|
+
}
|
65
|
+
```
|
66
|
+
|
67
|
+
These subscriptions are written to the `NulogyMessageBusProducer.subscriptions_table_name` table.
|
68
|
+
|
69
|
+
This style of subscriptions may be removed in a future release.
|
70
|
+
|
71
|
+
There is a [guide to migrate from Self-Serve to Configured](docs/self_serve_to_configured_subscriptions.md)
|
72
|
+
|
69
73
|
## Configuration
|
70
74
|
|
71
75
|
| Configuration | Default | Description |
|
72
76
|
|--------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------|
|
73
77
|
| context_for_subscription | `->(_subscription) { {} }` | A lambda used to inject any GraphQL Context to be used when producing subscription events |
|
74
78
|
| producing_events_fails_with | :raise | How the producer should handle errors when producing subscription events |
|
75
|
-
| subscriptions_table_name | "message_bus_subscriptions" | The name of the table for the
|
79
|
+
| subscriptions_table_name | "message_bus_subscriptions" | The name of the table for the SelfServeSubscription model |
|
76
80
|
| subscription_events_table_name | "message_bus_subscription_events" | The name of the table for the SubscriptionEvents model |
|
77
81
|
| add_subscription! | [] (i.e. empty) | Add a subscription via configuration. It will supercede any configured via GraphQL for a given id. |
|
78
82
|
|
@@ -129,11 +133,6 @@ module ExampleDomainPublicApi
|
|
129
133
|
class Schema < GraphQL::Schema
|
130
134
|
use NulogyMessageBusProducer::Subscriptions::PostgresTransport
|
131
135
|
|
132
|
-
# You must use the Interpreter, as it will be the new default.
|
133
|
-
# See more here: https://graphql-ruby.org/queries/interpreter
|
134
|
-
use GraphQL::Analysis::AST
|
135
|
-
use GraphQL::Execution::Interpreter
|
136
|
-
|
137
136
|
# This prevents subscriptions which contain arguments or expand lists form being registered.
|
138
137
|
# Expanding unbounded lists inside of an event may severely impact the performance of the system.
|
139
138
|
# Arguments are a source of variation that may not be appropriately tested.
|
@@ -283,4 +282,4 @@ You must be listed as a gem owner [on rubygems](https://rubygems.org/gems/nulogy
|
|
283
282
|
* Update `lib/nulogy_message_bus_producer/version.rb`
|
284
283
|
* Run `bundle install`
|
285
284
|
* Update the CHANGELOG
|
286
|
-
* Run `rake release`
|
285
|
+
* Run `bundle exec rake release`
|
@@ -55,7 +55,7 @@ module NulogyMessageBusProducer
|
|
55
55
|
|
56
56
|
schema_key = NulogyMessageBusProducer.resolve_schema_key(schema)
|
57
57
|
query_parser = Configuration::QueryParser.new(query)
|
58
|
-
subscription =
|
58
|
+
subscription = Subscriptions::ConfiguredSubscription.new(
|
59
59
|
id: query_parser.subscription_id,
|
60
60
|
subscription_group_id: query_parser.subscription_group_id,
|
61
61
|
schema_key: schema_key,
|
@@ -0,0 +1,18 @@
|
|
1
|
+
module NulogyMessageBusProducer
|
2
|
+
# This model saves self-serve subscriptions to external systems.
|
3
|
+
# An external system can subscribe to events and specify the shape of data it would like to receive for the event.
|
4
|
+
class SelfServeSubscription < ApplicationRecord
|
5
|
+
self.table_name = :message_bus_subscriptions
|
6
|
+
|
7
|
+
validates :id, presence: true
|
8
|
+
validates :subscription_group_id, presence: true
|
9
|
+
validates :schema_key, :event_type, presence: true
|
10
|
+
validates :query, :presence => true, "nulogy_message_bus_producer/subscriptions/valid_for_schema" => true
|
11
|
+
|
12
|
+
def self.create_or_update(attrs)
|
13
|
+
find_or_initialize_by(id: attrs[:id]).tap do |model|
|
14
|
+
model.update!(attrs)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
module NulogyMessageBusProducer
|
2
|
+
module Subscriptions
|
3
|
+
class ConfiguredSubscription
|
4
|
+
include ActiveModel::Model
|
5
|
+
|
6
|
+
attr_accessor :id, :subscription_group_id, :schema_key, :event_type, :query, :topic_name
|
7
|
+
|
8
|
+
validates :id, presence: true
|
9
|
+
validates :subscription_group_id, presence: true
|
10
|
+
validates :schema_key, :event_type, presence: true
|
11
|
+
validates :query, :presence => true, "nulogy_message_bus_producer/subscriptions/valid_for_schema" => true
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
@@ -15,7 +15,7 @@ module NulogyMessageBusProducer
|
|
15
15
|
|
16
16
|
# Note: raises like ActiveRecord#find
|
17
17
|
def find(id)
|
18
|
-
@config.configured_subscriptions.detect { |s| s.id == id } ||
|
18
|
+
@config.configured_subscriptions.detect { |s| s.id == id } || SelfServeSubscription.find(id)
|
19
19
|
end
|
20
20
|
|
21
21
|
def for_schema_event(schema_key, event_type)
|
@@ -27,7 +27,7 @@ module NulogyMessageBusProducer
|
|
27
27
|
private
|
28
28
|
|
29
29
|
def self_serve(schema_key, event_type)
|
30
|
-
|
30
|
+
SelfServeSubscription.where(event_type: event_type, schema_key: schema_key)
|
31
31
|
end
|
32
32
|
|
33
33
|
def configured(schema_key, event_type)
|
@@ -12,9 +12,9 @@ module NulogyMessageBusProducer
|
|
12
12
|
#
|
13
13
|
# NulogyMessageBusProducer.register_schema("some_schema", "SomeSchema")
|
14
14
|
class PostgresTransport < GraphQL::Subscriptions
|
15
|
-
def initialize(
|
15
|
+
def initialize(schema:, **_rest)
|
16
16
|
super
|
17
|
-
@schema_key = NulogyMessageBusProducer.resolve_schema_key(
|
17
|
+
@schema_key = NulogyMessageBusProducer.resolve_schema_key(schema)
|
18
18
|
end
|
19
19
|
|
20
20
|
def each_subscription_id(event)
|
@@ -50,7 +50,7 @@ module NulogyMessageBusProducer
|
|
50
50
|
|
51
51
|
def write_subscription(query, events)
|
52
52
|
events.each do |event|
|
53
|
-
|
53
|
+
SelfServeSubscription.create_or_update(
|
54
54
|
id: event.arguments.fetch(:subscription_id),
|
55
55
|
subscription_group_id: event.arguments.fetch(:subscription_group_id),
|
56
56
|
event_type: event.name,
|
@@ -63,7 +63,7 @@ module NulogyMessageBusProducer
|
|
63
63
|
|
64
64
|
# TODO: how is this invoked?
|
65
65
|
def delete_subscription(subscription_id)
|
66
|
-
|
66
|
+
SelfServeSubscription.find_by(id: subscription_id).destroy
|
67
67
|
end
|
68
68
|
|
69
69
|
private
|
@@ -14,7 +14,7 @@ module NulogyMessageBusProducer
|
|
14
14
|
@errors = []
|
15
15
|
end
|
16
16
|
|
17
|
-
def validate(subscription_or_subscriptions = NulogyMessageBusProducer::
|
17
|
+
def validate(subscription_or_subscriptions = NulogyMessageBusProducer::SelfServeSubscription.all)
|
18
18
|
Array(subscription_or_subscriptions).each do |subscription|
|
19
19
|
schema = find_schema(subscription)
|
20
20
|
next unless schema
|
@@ -0,0 +1,14 @@
|
|
1
|
+
module NulogyMessageBusProducer
|
2
|
+
module Subscriptions
|
3
|
+
class ValidForSchemaValidator < ActiveModel::EachValidator
|
4
|
+
def validate_each(record, attribute, _value)
|
5
|
+
return if record.schema_key.blank? || record.query.blank?
|
6
|
+
|
7
|
+
validator = NulogyMessageBusProducer::Subscriptions::QueryValidator.new
|
8
|
+
|
9
|
+
validator.validate(record)
|
10
|
+
validator.errors.each { |e| record.errors.add(attribute, e) }
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
@@ -1,4 +1,5 @@
|
|
1
1
|
require "graphql"
|
2
|
+
require "pp"
|
2
3
|
|
3
4
|
require "nulogy_message_bus_producer/config"
|
4
5
|
require "nulogy_message_bus_producer/configuration/query_parser"
|
@@ -15,11 +16,11 @@ module NulogyMessageBusProducer
|
|
15
16
|
end
|
16
17
|
|
17
18
|
def self.subscriptions_table_name=(table_name)
|
18
|
-
NulogyMessageBusProducer::
|
19
|
+
NulogyMessageBusProducer::SelfServeSubscription.table_name = table_name
|
19
20
|
end
|
20
21
|
|
21
22
|
def self.subscriptions_table_name
|
22
|
-
NulogyMessageBusProducer::
|
23
|
+
NulogyMessageBusProducer::SelfServeSubscription.table_name
|
23
24
|
end
|
24
25
|
|
25
26
|
def self.subscription_events_table_name=(table_name)
|
@@ -139,11 +140,13 @@ end
|
|
139
140
|
|
140
141
|
require "nulogy_message_bus_producer/application_record"
|
141
142
|
require "nulogy_message_bus_producer/base_subscription"
|
142
|
-
require "nulogy_message_bus_producer/subscription"
|
143
143
|
require "nulogy_message_bus_producer/subscription_event"
|
144
144
|
require "nulogy_message_bus_producer/repopulate_replication_slots"
|
145
145
|
require "nulogy_message_bus_producer/subscriptions/finder"
|
146
|
+
require "nulogy_message_bus_producer/subscriptions/no_variables"
|
146
147
|
require "nulogy_message_bus_producer/subscriptions/postgres_transport"
|
147
148
|
require "nulogy_message_bus_producer/subscriptions/query_validator"
|
148
|
-
require "nulogy_message_bus_producer/subscriptions/
|
149
|
+
require "nulogy_message_bus_producer/subscriptions/valid_for_schema_validator"
|
150
|
+
require "nulogy_message_bus_producer/subscriptions/configured_subscription"
|
151
|
+
require "nulogy_message_bus_producer/self_serve_subscription"
|
149
152
|
require "nulogy_message_bus_producer/subscriptions/risky_subscription_blocker"
|
data/spec/dummy/bin/setup
CHANGED
@@ -1,33 +1,32 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
|
-
require "pathname"
|
3
2
|
require "fileutils"
|
4
|
-
include FileUtils # rubocop:disable Style/MixinUsage
|
5
3
|
|
6
4
|
# path to your application root.
|
7
|
-
APP_ROOT =
|
5
|
+
APP_ROOT = File.expand_path("..", __dir__)
|
8
6
|
|
9
7
|
def system!(*args)
|
10
8
|
system(*args) || abort("\n== Command #{args} failed ==")
|
11
9
|
end
|
12
10
|
|
13
|
-
chdir APP_ROOT do
|
14
|
-
# This script is a
|
11
|
+
FileUtils.chdir APP_ROOT do
|
12
|
+
# This script is a way to set up or update your development environment automatically.
|
13
|
+
# This script is idempotent, so that you can run it at any time and get an expectable outcome.
|
15
14
|
# Add necessary setup steps to this file.
|
16
15
|
|
17
16
|
puts "== Installing dependencies =="
|
18
17
|
system! "gem install bundler --conservative"
|
19
18
|
system("bundle check") || system!("bundle install")
|
20
19
|
|
21
|
-
# Install JavaScript dependencies
|
22
|
-
|
20
|
+
# Install JavaScript dependencies
|
21
|
+
system! "bin/yarn"
|
23
22
|
|
24
23
|
# puts "\n== Copying sample files =="
|
25
24
|
# unless File.exist?('config/database.yml')
|
26
|
-
# cp 'config/database.yml.sample', 'config/database.yml'
|
25
|
+
# FileUtils.cp 'config/database.yml.sample', 'config/database.yml'
|
27
26
|
# end
|
28
27
|
|
29
28
|
puts "\n== Preparing database =="
|
30
|
-
system! "bin/rails db:
|
29
|
+
system! "bin/rails db:prepare"
|
31
30
|
|
32
31
|
puts "\n== Removing old logs and tempfiles =="
|
33
32
|
system! "bin/rails log:clear tmp:clear"
|
data/spec/dummy/bin/yarn
CHANGED
@@ -1,9 +1,17 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
|
-
|
3
|
-
Dir.chdir(
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
2
|
+
APP_ROOT = File.expand_path("..", __dir__)
|
3
|
+
Dir.chdir(APP_ROOT) do
|
4
|
+
yarn = ENV["PATH"].split(File::PATH_SEPARATOR)
|
5
|
+
.select { |dir| File.expand_path(dir) != __dir__ }
|
6
|
+
.product(["yarn", "yarn.cmd", "yarn.ps1"])
|
7
|
+
.map { |dir, file| File.expand_path(file, dir) }
|
8
|
+
.find { |file| File.executable?(file) }
|
9
|
+
|
10
|
+
if yarn
|
11
|
+
exec yarn, *ARGV
|
12
|
+
else
|
13
|
+
warn "Yarn executable was not detected in the system."
|
14
|
+
warn "Download Yarn at https://yarnpkg.com/en/docs/install"
|
15
|
+
exit 1
|
16
|
+
end
|
9
17
|
end
|
@@ -1,22 +1,27 @@
|
|
1
1
|
require_relative "boot"
|
2
2
|
|
3
3
|
require "rails/all"
|
4
|
+
require "nulogy_message_bus_producer"
|
4
5
|
|
6
|
+
# Require the gems listed in Gemfile, including any gems
|
7
|
+
# you've limited to :test, :development, or :production.
|
5
8
|
Bundler.require(*Rails.groups)
|
6
|
-
require "nulogy_message_bus_producer"
|
7
9
|
|
8
10
|
module Dummy
|
9
11
|
class Application < Rails::Application
|
10
12
|
# Initialize configuration defaults for originally generated Rails version.
|
11
13
|
config.load_defaults 5.1
|
12
14
|
|
13
|
-
#
|
14
|
-
#
|
15
|
-
#
|
16
|
-
config
|
15
|
+
# Configuration for the application, engines, and railties goes here.
|
16
|
+
#
|
17
|
+
# These settings can be overridden in specific environments using the files
|
18
|
+
# in config/environments, which are processed later.
|
19
|
+
#
|
20
|
+
# config.time_zone = "Central Time (US & Canada)"
|
21
|
+
# config.eager_load_paths << Rails.root.join("extras")
|
17
22
|
|
18
23
|
config.autoload_paths += %W[
|
19
|
-
#{config.root}/lib
|
24
|
+
"#{config.root}/lib"
|
20
25
|
]
|
21
26
|
end
|
22
27
|
end
|
data/spec/dummy/config/boot.rb
CHANGED
@@ -1,5 +1,3 @@
|
|
1
|
-
|
2
|
-
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../../Gemfile", __dir__)
|
1
|
+
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../Gemfile", __dir__)
|
3
2
|
|
4
|
-
require "bundler/setup"
|
5
|
-
$LOAD_PATH.unshift File.expand_path("../../../lib", __dir__)
|
3
|
+
require "bundler/setup" # Set up gems listed in the Gemfile.
|
data/spec/dummy/config/cable.yml
CHANGED
@@ -1,8 +1,10 @@
|
|
1
|
+
require "active_support/core_ext/integer/time"
|
2
|
+
|
1
3
|
Rails.application.configure do
|
2
4
|
# Settings specified here will take precedence over those in config/application.rb.
|
3
5
|
|
4
|
-
# In the development environment your application's code is reloaded
|
5
|
-
#
|
6
|
+
# In the development environment your application's code is reloaded any time
|
7
|
+
# it changes. This slows down response time but is perfect for development
|
6
8
|
# since you don't have to restart the web server when you make code changes.
|
7
9
|
config.cache_classes = false
|
8
10
|
|
@@ -13,12 +15,14 @@ Rails.application.configure do
|
|
13
15
|
config.consider_all_requests_local = true
|
14
16
|
|
15
17
|
# Enable/disable caching. By default caching is disabled.
|
16
|
-
|
18
|
+
# Run rails dev:cache to toggle caching.
|
19
|
+
if Rails.root.join("tmp", "caching-dev.txt").exist?
|
17
20
|
config.action_controller.perform_caching = true
|
21
|
+
config.action_controller.enable_fragment_cache_logging = true
|
18
22
|
|
19
23
|
config.cache_store = :memory_store
|
20
24
|
config.public_file_server.headers = {
|
21
|
-
"Cache-Control" => "public, max-age=#{2.days.
|
25
|
+
"Cache-Control" => "public, max-age=#{2.days.to_i}"
|
22
26
|
}
|
23
27
|
else
|
24
28
|
config.action_controller.perform_caching = false
|
@@ -26,6 +30,9 @@ Rails.application.configure do
|
|
26
30
|
config.cache_store = :null_store
|
27
31
|
end
|
28
32
|
|
33
|
+
# Store uploaded files on the local file system (see config/storage.yml for options).
|
34
|
+
config.active_storage.service = :local
|
35
|
+
|
29
36
|
# Don't care if the mailer can't send.
|
30
37
|
config.action_mailer.raise_delivery_errors = false
|
31
38
|
|
@@ -34,9 +41,18 @@ Rails.application.configure do
|
|
34
41
|
# Print deprecation notices to the Rails logger.
|
35
42
|
config.active_support.deprecation = :log
|
36
43
|
|
44
|
+
# Raise exceptions for disallowed deprecations.
|
45
|
+
config.active_support.disallowed_deprecation = :raise
|
46
|
+
|
47
|
+
# Tell Active Support which deprecation messages to disallow.
|
48
|
+
config.active_support.disallowed_deprecation_warnings = []
|
49
|
+
|
37
50
|
# Raise an error on page load if there are pending migrations.
|
38
51
|
config.active_record.migration_error = :page_load
|
39
52
|
|
53
|
+
# Highlight code that triggered database queries in logs.
|
54
|
+
config.active_record.verbose_query_logs = true
|
55
|
+
|
40
56
|
# Debug mode disables concatenation and preprocessing of assets.
|
41
57
|
# This option may cause significant delays in view rendering with a large
|
42
58
|
# number of complex assets.
|
@@ -45,10 +61,16 @@ Rails.application.configure do
|
|
45
61
|
# Suppress logger output for asset requests.
|
46
62
|
config.assets.quiet = true
|
47
63
|
|
48
|
-
# Raises error for missing translations
|
49
|
-
# config.
|
64
|
+
# Raises error for missing translations.
|
65
|
+
# config.i18n.raise_on_missing_translations = true
|
66
|
+
|
67
|
+
# Annotate rendered view with file names.
|
68
|
+
# config.action_view.annotate_rendered_view_with_filenames = true
|
50
69
|
|
51
70
|
# Use an evented file watcher to asynchronously detect changes in source code,
|
52
71
|
# routes, locales, etc. This feature depends on the listen gem.
|
53
|
-
|
72
|
+
config.file_watcher = ActiveSupport::EventedFileUpdateChecker
|
73
|
+
|
74
|
+
# Uncomment if you wish to allow Action Cable access from any origin.
|
75
|
+
# config.action_cable.disable_request_forgery_protection = true
|
54
76
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
require "active_support/core_ext/integer/time"
|
2
|
+
|
1
3
|
Rails.application.configure do
|
2
4
|
# Settings specified here will take precedence over those in config/application.rb.
|
3
5
|
|
@@ -14,32 +16,32 @@ Rails.application.configure do
|
|
14
16
|
config.consider_all_requests_local = false
|
15
17
|
config.action_controller.perform_caching = true
|
16
18
|
|
17
|
-
#
|
18
|
-
#
|
19
|
-
#
|
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
|
20
22
|
config.read_encrypted_secrets = false
|
21
23
|
|
22
24
|
# Disable serving static files from the `/public` folder by default since
|
23
25
|
# Apache or NGINX already handles this.
|
24
26
|
config.public_file_server.enabled = ENV["RAILS_SERVE_STATIC_FILES"].present?
|
25
27
|
|
26
|
-
# Compress
|
27
|
-
config.assets.js_compressor = :uglifier
|
28
|
+
# Compress CSS using a preprocessor.
|
28
29
|
# config.assets.css_compressor = :sass
|
29
30
|
|
30
31
|
# Do not fallback to assets pipeline if a precompiled asset is missed.
|
31
32
|
config.assets.compile = false
|
32
33
|
|
33
|
-
# `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb
|
34
|
-
|
35
34
|
# Enable serving of images, stylesheets, and JavaScripts from an asset server.
|
36
|
-
# config.
|
35
|
+
# config.asset_host = 'http://assets.example.com'
|
37
36
|
|
38
37
|
# Specifies the header that your server uses for sending files.
|
39
38
|
# config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
|
40
39
|
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
|
41
40
|
|
42
|
-
#
|
41
|
+
# Store uploaded files on the local file system (see config/storage.yml for options).
|
42
|
+
config.active_storage.service = :local
|
43
|
+
|
44
|
+
# Mount Action Cable outside main process or domain.
|
43
45
|
# config.action_cable.mount_path = nil
|
44
46
|
# config.action_cable.url = 'wss://example.com/cable'
|
45
47
|
# config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ]
|
@@ -47,9 +49,9 @@ Rails.application.configure do
|
|
47
49
|
# Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
|
48
50
|
# config.force_ssl = true
|
49
51
|
|
50
|
-
#
|
51
|
-
#
|
52
|
-
config.log_level = :
|
52
|
+
# Include generic and useful information about system operation, but avoid logging too much
|
53
|
+
# information to avoid inadvertent exposure of personally identifiable information (PII).
|
54
|
+
config.log_level = :info
|
53
55
|
|
54
56
|
# Prepend all log lines with the following tags.
|
55
57
|
config.log_tags = [:request_id]
|
@@ -57,9 +59,10 @@ Rails.application.configure do
|
|
57
59
|
# Use a different cache store in production.
|
58
60
|
# config.cache_store = :mem_cache_store
|
59
61
|
|
60
|
-
# Use a real queuing backend for Active Job (and separate queues per environment)
|
62
|
+
# Use a real queuing backend for Active Job (and separate queues per environment).
|
61
63
|
# config.active_job.queue_adapter = :resque
|
62
|
-
# config.active_job.queue_name_prefix = "
|
64
|
+
# config.active_job.queue_name_prefix = "dummy_production"
|
65
|
+
|
63
66
|
config.action_mailer.perform_caching = false
|
64
67
|
|
65
68
|
# Ignore bad email addresses and do not raise email delivery errors.
|
@@ -73,11 +76,17 @@ Rails.application.configure do
|
|
73
76
|
# Send deprecation notices to registered listeners.
|
74
77
|
config.active_support.deprecation = :notify
|
75
78
|
|
79
|
+
# Log disallowed deprecations.
|
80
|
+
config.active_support.disallowed_deprecation = :log
|
81
|
+
|
82
|
+
# Tell Active Support which deprecation messages to disallow.
|
83
|
+
config.active_support.disallowed_deprecation_warnings = []
|
84
|
+
|
76
85
|
# Use default logging formatter so that PID and timestamp are not suppressed.
|
77
86
|
config.log_formatter = ::Logger::Formatter.new
|
78
87
|
|
79
88
|
# Use a different logger for distributed setups.
|
80
|
-
# require
|
89
|
+
# require "syslog/logger"
|
81
90
|
# config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name')
|
82
91
|
|
83
92
|
if ENV["RAILS_LOG_TO_STDOUT"].present?
|
@@ -88,4 +97,25 @@ Rails.application.configure do
|
|
88
97
|
|
89
98
|
# Do not dump schema after migrations.
|
90
99
|
config.active_record.dump_schema_after_migration = false
|
100
|
+
|
101
|
+
# Inserts middleware to perform automatic connection switching.
|
102
|
+
# The `database_selector` hash is used to pass options to the DatabaseSelector
|
103
|
+
# middleware. The `delay` is used to determine how long to wait after a write
|
104
|
+
# to send a subsequent read to the primary.
|
105
|
+
#
|
106
|
+
# The `database_resolver` class is used by the middleware to determine which
|
107
|
+
# database is appropriate to use based on the time delay.
|
108
|
+
#
|
109
|
+
# The `database_resolver_context` class is used by the middleware to set
|
110
|
+
# timestamps for the last write to the primary. The resolver uses the context
|
111
|
+
# class timestamps to determine how long to wait before reading from the
|
112
|
+
# replica.
|
113
|
+
#
|
114
|
+
# By default Rails will store a last write timestamp in the session. The
|
115
|
+
# DatabaseSelector middleware is designed as such you can define your own
|
116
|
+
# strategy for connection switching and pass that into the middleware through
|
117
|
+
# these configuration options.
|
118
|
+
# config.active_record.database_selector = { delay: 2.seconds }
|
119
|
+
# config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver
|
120
|
+
# config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session
|
91
121
|
end
|
@@ -1,10 +1,13 @@
|
|
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
|
+
|
1
8
|
Rails.application.configure do
|
2
9
|
# Settings specified here will take precedence over those in config/application.rb.
|
3
10
|
|
4
|
-
# The test environment is used exclusively to run your application's
|
5
|
-
# test suite. You never need to work with it otherwise. Remember that
|
6
|
-
# your test database is "scratch space" for the test suite and is wiped
|
7
|
-
# and recreated between test runs. Don't rely on the data there!
|
8
11
|
config.cache_classes = true
|
9
12
|
|
10
13
|
# Do not eager load code on boot. This avoids loading your whole application
|
@@ -15,18 +18,23 @@ Rails.application.configure do
|
|
15
18
|
# Configure public file server for tests with Cache-Control for performance.
|
16
19
|
config.public_file_server.enabled = true
|
17
20
|
config.public_file_server.headers = {
|
18
|
-
"Cache-Control" => "public, max-age=#{1.hour.
|
21
|
+
"Cache-Control" => "public, max-age=#{1.hour.to_i}"
|
19
22
|
}
|
20
23
|
|
21
24
|
# Show full error reports and disable caching.
|
22
25
|
config.consider_all_requests_local = true
|
23
26
|
config.action_controller.perform_caching = false
|
27
|
+
config.cache_store = :null_store
|
24
28
|
|
25
29
|
# Raise exceptions instead of rendering exception templates.
|
26
30
|
config.action_dispatch.show_exceptions = false
|
27
31
|
|
28
32
|
# Disable request forgery protection in test environment.
|
29
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
|
+
|
30
38
|
config.action_mailer.perform_caching = false
|
31
39
|
|
32
40
|
# Tell Action Mailer not to deliver emails to the real world.
|
@@ -37,6 +45,15 @@ Rails.application.configure do
|
|
37
45
|
# Print deprecation notices to the stderr.
|
38
46
|
config.active_support.deprecation = :stderr
|
39
47
|
|
40
|
-
#
|
41
|
-
|
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
|
42
59
|
end
|