cm_page_builder 0.2.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 +7 -0
- data/MIT-LICENSE +20 -0
- data/README.md +65 -0
- data/Rakefile +30 -0
- data/app/assets/config/cm_page_builder_rails_manifest.js +1 -0
- data/app/assets/stylesheets/cm_page_builder/rails/application.css +15 -0
- data/app/assets/stylesheets/cm_page_builder/rails/page_components.css +4 -0
- data/app/assets/stylesheets/cm_page_builder/rails/pages.css +4 -0
- data/app/assets/stylesheets/scaffold.css +80 -0
- data/app/controllers/cm_page_builder/rails/application_controller.rb +14 -0
- data/app/controllers/cm_page_builder/rails/pages_controller.rb +65 -0
- data/app/helpers/cm_page_builder/rails/application_helper.rb +6 -0
- data/app/helpers/cm_page_builder/rails/page_components_helper.rb +4 -0
- data/app/helpers/cm_page_builder/rails/pages_helper.rb +4 -0
- data/app/jobs/cm_page_builder/rails/application_job.rb +6 -0
- data/app/mailers/cm_page_builder/rails/application_mailer.rb +8 -0
- data/app/models/cm_page_builder/rails/application_record.rb +7 -0
- data/app/models/cm_page_builder/rails/page.rb +76 -0
- data/app/models/cm_page_builder/rails/page_component.rb +16 -0
- data/app/models/concerns/cm_page_builder/rails/has_cm_content.rb +20 -0
- data/app/views/cm_page_builder/rails/pages/_form.html.slim +13 -0
- data/app/views/cm_page_builder/rails/pages/edit.html.slim +5 -0
- data/app/views/cm_page_builder/rails/pages/show.html.slim +3 -0
- data/app/views/layouts/cm_page_builder/rails/application.html.erb +15 -0
- data/config/routes.rb +8 -0
- data/db/migrate/20190816103148_create_cm_page_builder_rails_pages.rb +9 -0
- data/db/migrate/20190816105056_create_cm_page_builder_rails_page_components.rb +13 -0
- data/db/migrate/20190903110322_change_page_component_primary_key.rb +11 -0
- data/lib/cm_page_builder/rails/application_helper.rb +33 -0
- data/lib/cm_page_builder/rails/engine.rb +22 -0
- data/lib/cm_page_builder/rails/version.rb +5 -0
- data/lib/cm_page_builder/rails.rb +8 -0
- data/lib/generators/cm_page_builder/rails/install_generator.rb +14 -0
- data/lib/generators/cm_page_builder/rails/templates/app/javascripts/components/cm_content_manager/Content.jsx +46 -0
- data/lib/tasks/cm_page_builder/rails_tasks.rake +4 -0
- data/spec/dummy/Rakefile +6 -0
- data/spec/dummy/app/assets/config/manifest.js +3 -0
- data/spec/dummy/app/assets/stylesheets/application.css +15 -0
- data/spec/dummy/app/channels/application_cable/channel.rb +4 -0
- data/spec/dummy/app/channels/application_cable/connection.rb +4 -0
- data/spec/dummy/app/controllers/application_controller.rb +2 -0
- data/spec/dummy/app/controllers/test_containers_controller.rb +43 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/javascript/packs/application.js +15 -0
- data/spec/dummy/app/jobs/application_job.rb +7 -0
- data/spec/dummy/app/models/application_record.rb +3 -0
- data/spec/dummy/app/models/test_container.rb +3 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/app/views/test_containers/_form.html.slim +10 -0
- data/spec/dummy/app/views/test_containers/edit.html.slim +7 -0
- data/spec/dummy/app/views/test_containers/index.html.slim +21 -0
- data/spec/dummy/app/views/test_containers/new.html.slim +5 -0
- data/spec/dummy/app/views/test_containers/show.html.slim +3 -0
- data/spec/dummy/bin/rails +4 -0
- data/spec/dummy/bin/rake +4 -0
- data/spec/dummy/bin/setup +33 -0
- data/spec/dummy/config/application.rb +30 -0
- data/spec/dummy/config/boot.rb +5 -0
- data/spec/dummy/config/cable.yml +10 -0
- data/spec/dummy/config/database.yml +85 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +57 -0
- data/spec/dummy/config/environments/production.rb +106 -0
- data/spec/dummy/config/environments/test.rb +41 -0
- data/spec/dummy/config/initializers/application_controller_renderer.rb +8 -0
- data/spec/dummy/config/initializers/assets.rb +12 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/content_security_policy.rb +28 -0
- data/spec/dummy/config/initializers/cookies_serializer.rb +5 -0
- data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/spec/dummy/config/initializers/inflections.rb +16 -0
- data/spec/dummy/config/initializers/mime_types.rb +4 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/en.yml +33 -0
- data/spec/dummy/config/puma.rb +35 -0
- data/spec/dummy/config/routes.rb +4 -0
- data/spec/dummy/config/spring.rb +6 -0
- data/spec/dummy/config/storage.yml +34 -0
- data/spec/dummy/config.ru +5 -0
- data/spec/dummy/db/migrate/20190930111315_create_test_containers.rb +9 -0
- data/spec/dummy/db/migrate/20190930120755_create_active_storage_tables.active_storage.rb +27 -0
- data/spec/dummy/db/migrate/20191114114259_create_cm_page_builder_rails_pages.cm_page_builder_rails.rb +10 -0
- data/spec/dummy/db/migrate/20191114114260_create_cm_page_builder_rails_page_components.cm_page_builder_rails.rb +14 -0
- data/spec/dummy/db/migrate/20191114114261_change_page_component_primary_key.cm_page_builder_rails.rb +12 -0
- data/spec/dummy/db/schema.rb +66 -0
- data/spec/dummy/public/404.html +67 -0
- data/spec/dummy/public/422.html +67 -0
- data/spec/dummy/public/500.html +66 -0
- data/spec/dummy/public/apple-touch-icon-precomposed.png +0 -0
- data/spec/dummy/public/apple-touch-icon.png +0 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/spec/models/test_container_spec.rb +5 -0
- data/spec/fixtures/files/commutatus_logo.png +0 -0
- data/spec/models/cm_page_builder/rails/page_spec.rb +50 -0
- data/spec/rails_helper.rb +62 -0
- data/spec/spec_helper.rb +96 -0
- metadata +256 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import React from "react"
|
|
2
|
+
import PropTypes from "prop-types"
|
|
3
|
+
import PageBuilder from 'cm-page-builder'
|
|
4
|
+
|
|
5
|
+
class Content extends React.Component {
|
|
6
|
+
constructor(props) {
|
|
7
|
+
super(props)
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
_updatePageComponent = (id, data, type, key) => {}
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
render () {
|
|
15
|
+
return (
|
|
16
|
+
<React.Fragment>
|
|
17
|
+
<PageBuilder
|
|
18
|
+
pageComponents={this.props.components}
|
|
19
|
+
handleUpdate={this._updatePageComponent}
|
|
20
|
+
updateComponentData={(data) =>
|
|
21
|
+
{ $(`#${this.props.input}`).val(JSON.stringify(data))}
|
|
22
|
+
}
|
|
23
|
+
showTitle={false}
|
|
24
|
+
showEmoji={false}
|
|
25
|
+
showPageInfo={false}
|
|
26
|
+
useDirectStorageUpload={true}
|
|
27
|
+
assetBaseUrl={ this.props.assetBaseUrl }
|
|
28
|
+
meta={ {id: "debug"} }
|
|
29
|
+
status={ this.props.status }
|
|
30
|
+
/>
|
|
31
|
+
</React.Fragment>
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
Content.defaultProps = {
|
|
37
|
+
status: 'Edit'
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
Content.propTypes = {
|
|
41
|
+
input: PropTypes.string,
|
|
42
|
+
components: PropTypes.array,
|
|
43
|
+
assetBaseUrl: PropTypes.string,
|
|
44
|
+
status: PropTypes.string
|
|
45
|
+
};
|
|
46
|
+
export default Content
|
data/spec/dummy/Rakefile
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
|
3
|
+
* listed below.
|
|
4
|
+
*
|
|
5
|
+
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
|
6
|
+
* or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path.
|
|
7
|
+
*
|
|
8
|
+
* You're free to add application-wide styles to this file and they'll appear at the bottom of the
|
|
9
|
+
* compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS
|
|
10
|
+
* files in this directory. Styles in this file should be added after the last require_* statement.
|
|
11
|
+
* It is generally better to create a new file per style scope.
|
|
12
|
+
*
|
|
13
|
+
*= require_tree .
|
|
14
|
+
*= require_self
|
|
15
|
+
*/
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
class TestContainersController < ApplicationController
|
|
2
|
+
before_action :set_test_container, only: [:show, :edit, :update, :destroy]
|
|
3
|
+
def index
|
|
4
|
+
@test_containers = TestContainer.all
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
def show
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def new
|
|
11
|
+
@test_container = TestContainer.new
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def edit
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def create
|
|
18
|
+
@test_container = test_container.new(test_container_params)
|
|
19
|
+
if @test_container.save
|
|
20
|
+
@test_container.save_content(components)
|
|
21
|
+
redirect_to @test_container, notice: 'test_container was successfully created.'
|
|
22
|
+
else
|
|
23
|
+
render :new
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def update
|
|
28
|
+
if @test_container.save_content(components)
|
|
29
|
+
redirect_to @test_container, notice: 'test_container was successfully updated.'
|
|
30
|
+
else
|
|
31
|
+
render :edit
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
def set_test_container
|
|
36
|
+
@test_container = TestContainer.find(params[:id])
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
# Only allow a trusted parameter "white list" through.
|
|
40
|
+
def test_container_params
|
|
41
|
+
params.require(:test_container).permit
|
|
42
|
+
end
|
|
43
|
+
end
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
|
2
|
+
// listed below.
|
|
3
|
+
//
|
|
4
|
+
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
|
5
|
+
// or any plugin's vendor/assets/javascripts directory can be referenced here using a relative path.
|
|
6
|
+
//
|
|
7
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
|
8
|
+
// compiled file. JavaScript code in this file should be added after the last require_* statement.
|
|
9
|
+
//
|
|
10
|
+
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
|
|
11
|
+
// about supported directives.
|
|
12
|
+
//
|
|
13
|
+
//= require rails-ujs
|
|
14
|
+
//= require activestorage
|
|
15
|
+
//= require_tree .
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
class ApplicationJob < ActiveJob::Base
|
|
2
|
+
# Automatically retry jobs that encountered a deadlock
|
|
3
|
+
# retry_on ActiveRecord::Deadlocked
|
|
4
|
+
|
|
5
|
+
# Most jobs are safe to ignore if the underlying records are no longer available
|
|
6
|
+
# discard_on ActiveJob::DeserializationError
|
|
7
|
+
end
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
= form_for @test_container do |f|
|
|
2
|
+
- if @test_container.errors.any?
|
|
3
|
+
#error_explanation
|
|
4
|
+
h2 = "#{pluralize(@test_container.errors.count, "error")} prohibited this test container from being saved:"
|
|
5
|
+
ul
|
|
6
|
+
- @test_container.errors.full_messages.each do |message|
|
|
7
|
+
li = message
|
|
8
|
+
|
|
9
|
+
.field
|
|
10
|
+
.actions = f.submit
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
h1 Listing test_containers
|
|
2
|
+
|
|
3
|
+
table
|
|
4
|
+
thead
|
|
5
|
+
tr
|
|
6
|
+
th Test container
|
|
7
|
+
th
|
|
8
|
+
th
|
|
9
|
+
th
|
|
10
|
+
|
|
11
|
+
tbody
|
|
12
|
+
- @test_containers.each do |test_container|
|
|
13
|
+
tr
|
|
14
|
+
td = test_container
|
|
15
|
+
td = link_to 'Show', test_container
|
|
16
|
+
td = link_to 'Edit', edit_test_container_path(test_container)
|
|
17
|
+
td = link_to 'Destroy', test_container, data: { confirm: 'Are you sure?' }, method: :delete
|
|
18
|
+
|
|
19
|
+
br
|
|
20
|
+
|
|
21
|
+
= link_to 'New Test Container', new_test_container_path
|
data/spec/dummy/bin/rake
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
require 'fileutils'
|
|
3
|
+
|
|
4
|
+
# path to your application root.
|
|
5
|
+
APP_ROOT = File.expand_path('..', __dir__)
|
|
6
|
+
|
|
7
|
+
def system!(*args)
|
|
8
|
+
system(*args) || abort("\n== Command #{args} failed ==")
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
FileUtils.chdir APP_ROOT do
|
|
12
|
+
# This script is a way to setup or update your development environment automatically.
|
|
13
|
+
# This script is idempotent, so that you can run it at anytime and get an expectable outcome.
|
|
14
|
+
# Add necessary setup steps to this file.
|
|
15
|
+
|
|
16
|
+
puts '== Installing dependencies =='
|
|
17
|
+
system! 'gem install bundler --conservative'
|
|
18
|
+
system('bundle check') || system!('bundle install')
|
|
19
|
+
|
|
20
|
+
# puts "\n== Copying sample files =="
|
|
21
|
+
# unless File.exist?('config/database.yml')
|
|
22
|
+
# FileUtils.cp 'config/database.yml.sample', 'config/database.yml'
|
|
23
|
+
# end
|
|
24
|
+
|
|
25
|
+
puts "\n== Preparing database =="
|
|
26
|
+
system! 'bin/rails db:prepare'
|
|
27
|
+
|
|
28
|
+
puts "\n== Removing old logs and tempfiles =="
|
|
29
|
+
system! 'bin/rails log:clear tmp:clear'
|
|
30
|
+
|
|
31
|
+
puts "\n== Restarting application server =="
|
|
32
|
+
system! 'bin/rails restart'
|
|
33
|
+
end
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
require_relative 'boot'
|
|
2
|
+
|
|
3
|
+
require "rails"
|
|
4
|
+
# Pick the frameworks you want:
|
|
5
|
+
require "active_model/railtie"
|
|
6
|
+
require "active_job/railtie"
|
|
7
|
+
require "active_record/railtie"
|
|
8
|
+
require "active_storage/engine"
|
|
9
|
+
require "action_controller/railtie"
|
|
10
|
+
# require "action_mailer/railtie"
|
|
11
|
+
require "action_view/railtie"
|
|
12
|
+
require "action_cable/engine"
|
|
13
|
+
require "sprockets/railtie"
|
|
14
|
+
require "rails/test_unit/railtie"
|
|
15
|
+
|
|
16
|
+
Bundler.require(*Rails.groups)
|
|
17
|
+
require "cm_page_builder/rails"
|
|
18
|
+
|
|
19
|
+
module Dummy
|
|
20
|
+
class Application < Rails::Application
|
|
21
|
+
# Initialize configuration defaults for originally generated Rails version.
|
|
22
|
+
config.load_defaults 6.0
|
|
23
|
+
|
|
24
|
+
# Settings in config/environments/* take precedence over those specified here.
|
|
25
|
+
# Application configuration can go into files in config/initializers
|
|
26
|
+
# -- all .rb files in that directory are automatically loaded after loading
|
|
27
|
+
# the framework and any gems in your application.
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
# PostgreSQL. Versions 9.3 and up are supported.
|
|
2
|
+
#
|
|
3
|
+
# Install the pg driver:
|
|
4
|
+
# gem install pg
|
|
5
|
+
# On macOS with Homebrew:
|
|
6
|
+
# gem install pg -- --with-pg-config=/usr/local/bin/pg_config
|
|
7
|
+
# On macOS with MacPorts:
|
|
8
|
+
# gem install pg -- --with-pg-config=/opt/local/lib/postgresql84/bin/pg_config
|
|
9
|
+
# On Windows:
|
|
10
|
+
# gem install pg
|
|
11
|
+
# Choose the win32 build.
|
|
12
|
+
# Install PostgreSQL and put its /bin directory on your path.
|
|
13
|
+
#
|
|
14
|
+
# Configure Using Gemfile
|
|
15
|
+
# gem 'pg'
|
|
16
|
+
#
|
|
17
|
+
default: &default
|
|
18
|
+
adapter: postgresql
|
|
19
|
+
encoding: unicode
|
|
20
|
+
# For details on connection pooling, see Rails configuration guide
|
|
21
|
+
# https://guides.rubyonrails.org/configuring.html#database-pooling
|
|
22
|
+
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
|
|
23
|
+
|
|
24
|
+
development:
|
|
25
|
+
<<: *default
|
|
26
|
+
database: dummy_cm_page_builder
|
|
27
|
+
|
|
28
|
+
# The specified database role being used to connect to postgres.
|
|
29
|
+
# To create additional roles in postgres see `$ createuser --help`.
|
|
30
|
+
# When left blank, postgres will use the default role. This is
|
|
31
|
+
# the same name as the operating system user that initialized the database.
|
|
32
|
+
#username: dummy
|
|
33
|
+
|
|
34
|
+
# The password associated with the postgres role (username).
|
|
35
|
+
#password:
|
|
36
|
+
|
|
37
|
+
# Connect on a TCP socket. Omitted by default since the client uses a
|
|
38
|
+
# domain socket that doesn't need configuration. Windows does not have
|
|
39
|
+
# domain sockets, so uncomment these lines.
|
|
40
|
+
#host: localhost
|
|
41
|
+
|
|
42
|
+
# The TCP port the server listens on. Defaults to 5432.
|
|
43
|
+
# If your server runs on a different port number, change accordingly.
|
|
44
|
+
#port: 5432
|
|
45
|
+
|
|
46
|
+
# Schema search path. The server defaults to $user,public
|
|
47
|
+
#schema_search_path: myapp,sharedapp,public
|
|
48
|
+
|
|
49
|
+
# Minimum log levels, in increasing order:
|
|
50
|
+
# debug5, debug4, debug3, debug2, debug1,
|
|
51
|
+
# log, notice, warning, error, fatal, and panic
|
|
52
|
+
# Defaults to warning.
|
|
53
|
+
#min_messages: notice
|
|
54
|
+
|
|
55
|
+
# Warning: The database defined as "test" will be erased and
|
|
56
|
+
# re-generated from your development database when you run "rake".
|
|
57
|
+
# Do not set this db to the same as development or production.
|
|
58
|
+
test:
|
|
59
|
+
<<: *default
|
|
60
|
+
database: dummy_test
|
|
61
|
+
|
|
62
|
+
# As with config/credentials.yml, you never want to store sensitive information,
|
|
63
|
+
# like your database password, in your source code. If your source code is
|
|
64
|
+
# ever seen by anyone, they now have access to your database.
|
|
65
|
+
#
|
|
66
|
+
# Instead, provide the password as a unix environment variable when you boot
|
|
67
|
+
# the app. Read https://guides.rubyonrails.org/configuring.html#configuring-a-database
|
|
68
|
+
# for a full rundown on how to provide these environment variables in a
|
|
69
|
+
# production deployment.
|
|
70
|
+
#
|
|
71
|
+
# On Heroku and other platform providers, you may have a full connection URL
|
|
72
|
+
# available as an environment variable. For example:
|
|
73
|
+
#
|
|
74
|
+
# DATABASE_URL="postgres://myuser:mypass@localhost/somedatabase"
|
|
75
|
+
#
|
|
76
|
+
# You can use this database configuration with:
|
|
77
|
+
#
|
|
78
|
+
# production:
|
|
79
|
+
# url: <%= ENV['DATABASE_URL'] %>
|
|
80
|
+
#
|
|
81
|
+
production:
|
|
82
|
+
<<: *default
|
|
83
|
+
database: dummy_production
|
|
84
|
+
username: dummy
|
|
85
|
+
password: <%= ENV['DUMMY_DATABASE_PASSWORD'] %>
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
Rails.application.configure do
|
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb.
|
|
3
|
+
|
|
4
|
+
# In the development environment your application's code is reloaded on
|
|
5
|
+
# every request. This slows down response time but is perfect for development
|
|
6
|
+
# since you don't have to restart the web server when you make code changes.
|
|
7
|
+
config.cache_classes = false
|
|
8
|
+
|
|
9
|
+
# Do not eager load code on boot.
|
|
10
|
+
config.eager_load = false
|
|
11
|
+
|
|
12
|
+
# Show full error reports.
|
|
13
|
+
config.consider_all_requests_local = true
|
|
14
|
+
|
|
15
|
+
# Enable/disable caching. By default caching is disabled.
|
|
16
|
+
# Run rails dev:cache to toggle caching.
|
|
17
|
+
if Rails.root.join('tmp', 'caching-dev.txt').exist?
|
|
18
|
+
config.action_controller.perform_caching = true
|
|
19
|
+
config.action_controller.enable_fragment_cache_logging = true
|
|
20
|
+
|
|
21
|
+
config.cache_store = :memory_store
|
|
22
|
+
config.public_file_server.headers = {
|
|
23
|
+
'Cache-Control' => "public, max-age=#{2.days.to_i}"
|
|
24
|
+
}
|
|
25
|
+
else
|
|
26
|
+
config.action_controller.perform_caching = false
|
|
27
|
+
|
|
28
|
+
config.cache_store = :null_store
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
# Store uploaded files on the local file system (see config/storage.yml for options).
|
|
32
|
+
config.active_storage.service = :local
|
|
33
|
+
|
|
34
|
+
# Print deprecation notices to the Rails logger.
|
|
35
|
+
config.active_support.deprecation = :log
|
|
36
|
+
|
|
37
|
+
# Raise an error on page load if there are pending migrations.
|
|
38
|
+
config.active_record.migration_error = :page_load
|
|
39
|
+
|
|
40
|
+
# Highlight code that triggered database queries in logs.
|
|
41
|
+
config.active_record.verbose_query_logs = true
|
|
42
|
+
|
|
43
|
+
# Debug mode disables concatenation and preprocessing of assets.
|
|
44
|
+
# This option may cause significant delays in view rendering with a large
|
|
45
|
+
# number of complex assets.
|
|
46
|
+
config.assets.debug = true
|
|
47
|
+
|
|
48
|
+
# Suppress logger output for asset requests.
|
|
49
|
+
config.assets.quiet = true
|
|
50
|
+
|
|
51
|
+
# Raises error for missing translations.
|
|
52
|
+
# config.action_view.raise_on_missing_translations = true
|
|
53
|
+
|
|
54
|
+
# Use an evented file watcher to asynchronously detect changes in source code,
|
|
55
|
+
# routes, locales, etc. This feature depends on the listen gem.
|
|
56
|
+
# config.file_watcher = ActiveSupport::EventedFileUpdateChecker
|
|
57
|
+
end
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
Rails.application.configure do
|
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb.
|
|
3
|
+
|
|
4
|
+
# Code is not reloaded between requests.
|
|
5
|
+
config.cache_classes = true
|
|
6
|
+
|
|
7
|
+
# Eager load code on boot. This eager loads most of Rails and
|
|
8
|
+
# your application in memory, allowing both threaded web servers
|
|
9
|
+
# and those relying on copy on write to perform better.
|
|
10
|
+
# Rake tasks automatically ignore this option for performance.
|
|
11
|
+
config.eager_load = true
|
|
12
|
+
|
|
13
|
+
# Full error reports are disabled and caching is turned on.
|
|
14
|
+
config.consider_all_requests_local = false
|
|
15
|
+
config.action_controller.perform_caching = true
|
|
16
|
+
|
|
17
|
+
# Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"]
|
|
18
|
+
# or in config/master.key. This key is used to decrypt credentials (and other encrypted files).
|
|
19
|
+
# config.require_master_key = true
|
|
20
|
+
|
|
21
|
+
# Disable serving static files from the `/public` folder by default since
|
|
22
|
+
# Apache or NGINX already handles this.
|
|
23
|
+
config.public_file_server.enabled = ENV['RAILS_SERVE_STATIC_FILES'].present?
|
|
24
|
+
|
|
25
|
+
# Compress CSS using a preprocessor.
|
|
26
|
+
# config.assets.css_compressor = :sass
|
|
27
|
+
|
|
28
|
+
# Do not fallback to assets pipeline if a precompiled asset is missed.
|
|
29
|
+
config.assets.compile = false
|
|
30
|
+
|
|
31
|
+
# Enable serving of images, stylesheets, and JavaScripts from an asset server.
|
|
32
|
+
# config.action_controller.asset_host = 'http://assets.example.com'
|
|
33
|
+
|
|
34
|
+
# Specifies the header that your server uses for sending files.
|
|
35
|
+
# config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
|
|
36
|
+
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
|
|
37
|
+
|
|
38
|
+
# Store uploaded files on the local file system (see config/storage.yml for options).
|
|
39
|
+
config.active_storage.service = :local
|
|
40
|
+
|
|
41
|
+
# Mount Action Cable outside main process or domain.
|
|
42
|
+
# config.action_cable.mount_path = nil
|
|
43
|
+
# config.action_cable.url = 'wss://example.com/cable'
|
|
44
|
+
# config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ]
|
|
45
|
+
|
|
46
|
+
# Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
|
|
47
|
+
# config.force_ssl = true
|
|
48
|
+
|
|
49
|
+
# Use the lowest log level to ensure availability of diagnostic information
|
|
50
|
+
# when problems arise.
|
|
51
|
+
config.log_level = :debug
|
|
52
|
+
|
|
53
|
+
# Prepend all log lines with the following tags.
|
|
54
|
+
config.log_tags = [ :request_id ]
|
|
55
|
+
|
|
56
|
+
# Use a different cache store in production.
|
|
57
|
+
# config.cache_store = :mem_cache_store
|
|
58
|
+
|
|
59
|
+
# Use a real queuing backend for Active Job (and separate queues per environment).
|
|
60
|
+
# config.active_job.queue_adapter = :resque
|
|
61
|
+
# config.active_job.queue_name_prefix = "dummy_production"
|
|
62
|
+
|
|
63
|
+
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
|
64
|
+
# the I18n.default_locale when a translation cannot be found).
|
|
65
|
+
config.i18n.fallbacks = true
|
|
66
|
+
|
|
67
|
+
# Send deprecation notices to registered listeners.
|
|
68
|
+
config.active_support.deprecation = :notify
|
|
69
|
+
|
|
70
|
+
# Use default logging formatter so that PID and timestamp are not suppressed.
|
|
71
|
+
config.log_formatter = ::Logger::Formatter.new
|
|
72
|
+
|
|
73
|
+
# Use a different logger for distributed setups.
|
|
74
|
+
# require 'syslog/logger'
|
|
75
|
+
# config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name')
|
|
76
|
+
|
|
77
|
+
if ENV["RAILS_LOG_TO_STDOUT"].present?
|
|
78
|
+
logger = ActiveSupport::Logger.new(STDOUT)
|
|
79
|
+
logger.formatter = config.log_formatter
|
|
80
|
+
config.logger = ActiveSupport::TaggedLogging.new(logger)
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
# Do not dump schema after migrations.
|
|
84
|
+
config.active_record.dump_schema_after_migration = false
|
|
85
|
+
|
|
86
|
+
# Inserts middleware to perform automatic connection switching.
|
|
87
|
+
# The `database_selector` hash is used to pass options to the DatabaseSelector
|
|
88
|
+
# middleware. The `delay` is used to determine how long to wait after a write
|
|
89
|
+
# to send a subsequent read to the primary.
|
|
90
|
+
#
|
|
91
|
+
# The `database_resolver` class is used by the middleware to determine which
|
|
92
|
+
# database is appropriate to use based on the time delay.
|
|
93
|
+
#
|
|
94
|
+
# The `database_resolver_context` class is used by the middleware to set
|
|
95
|
+
# timestamps for the last write to the primary. The resolver uses the context
|
|
96
|
+
# class timestamps to determine how long to wait before reading from the
|
|
97
|
+
# replica.
|
|
98
|
+
#
|
|
99
|
+
# By default Rails will store a last write timestamp in the session. The
|
|
100
|
+
# DatabaseSelector middleware is designed as such you can define your own
|
|
101
|
+
# strategy for connection switching and pass that into the middleware through
|
|
102
|
+
# these configuration options.
|
|
103
|
+
# config.active_record.database_selector = { delay: 2.seconds }
|
|
104
|
+
# config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver
|
|
105
|
+
# config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session
|
|
106
|
+
end
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
# The test environment is used exclusively to run your application's
|
|
2
|
+
# test suite. You never need to work with it otherwise. Remember that
|
|
3
|
+
# your test database is "scratch space" for the test suite and is wiped
|
|
4
|
+
# and recreated between test runs. Don't rely on the data there!
|
|
5
|
+
|
|
6
|
+
Rails.application.configure do
|
|
7
|
+
# Settings specified here will take precedence over those in config/application.rb.
|
|
8
|
+
|
|
9
|
+
config.cache_classes = false
|
|
10
|
+
|
|
11
|
+
# Do not eager load code on boot. This avoids loading your whole application
|
|
12
|
+
# just for the purpose of running a single test. If you are using a tool that
|
|
13
|
+
# preloads Rails for running tests, you may have to set it to true.
|
|
14
|
+
config.eager_load = false
|
|
15
|
+
|
|
16
|
+
# Configure public file server for tests with Cache-Control for performance.
|
|
17
|
+
config.public_file_server.enabled = true
|
|
18
|
+
config.public_file_server.headers = {
|
|
19
|
+
'Cache-Control' => "public, max-age=#{1.hour.to_i}"
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
# Show full error reports and disable caching.
|
|
23
|
+
config.consider_all_requests_local = true
|
|
24
|
+
config.action_controller.perform_caching = false
|
|
25
|
+
config.cache_store = :null_store
|
|
26
|
+
|
|
27
|
+
# Raise exceptions instead of rendering exception templates.
|
|
28
|
+
config.action_dispatch.show_exceptions = false
|
|
29
|
+
|
|
30
|
+
# Disable request forgery protection in test environment.
|
|
31
|
+
config.action_controller.allow_forgery_protection = false
|
|
32
|
+
|
|
33
|
+
# Store uploaded files on the local file system in a temporary directory.
|
|
34
|
+
config.active_storage.service = :test
|
|
35
|
+
|
|
36
|
+
# Print deprecation notices to the stderr.
|
|
37
|
+
config.active_support.deprecation = :stderr
|
|
38
|
+
|
|
39
|
+
# Raises error for missing translations.
|
|
40
|
+
# config.action_view.raise_on_missing_translations = true
|
|
41
|
+
end
|