rails_attr_enum 0.0.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.
Files changed (53) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +20 -0
  3. data/README.rdoc +3 -0
  4. data/Rakefile +32 -0
  5. data/lib/rails_attr_enum/attr.rb +11 -0
  6. data/lib/rails_attr_enum/entry.rb +6 -0
  7. data/lib/rails_attr_enum/entry_value.rb +44 -0
  8. data/lib/rails_attr_enum/enum.rb +53 -0
  9. data/lib/rails_attr_enum/enum_accumulator.rb +81 -0
  10. data/lib/rails_attr_enum/version.rb +3 -0
  11. data/lib/rails_attr_enum.rb +98 -0
  12. data/lib/tasks/rails_attr_enum_tasks.rake +4 -0
  13. data/test/dummy/README.rdoc +28 -0
  14. data/test/dummy/Rakefile +6 -0
  15. data/test/dummy/app/assets/javascripts/application.js +13 -0
  16. data/test/dummy/app/assets/stylesheets/application.css +13 -0
  17. data/test/dummy/app/controllers/application_controller.rb +5 -0
  18. data/test/dummy/app/helpers/application_helper.rb +2 -0
  19. data/test/dummy/app/models/user.rb +5 -0
  20. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  21. data/test/dummy/bin/bundle +3 -0
  22. data/test/dummy/bin/rails +4 -0
  23. data/test/dummy/bin/rake +4 -0
  24. data/test/dummy/config/application.rb +23 -0
  25. data/test/dummy/config/boot.rb +5 -0
  26. data/test/dummy/config/database.yml +25 -0
  27. data/test/dummy/config/environment.rb +5 -0
  28. data/test/dummy/config/environments/development.rb +29 -0
  29. data/test/dummy/config/environments/production.rb +80 -0
  30. data/test/dummy/config/environments/test.rb +36 -0
  31. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  32. data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  33. data/test/dummy/config/initializers/inflections.rb +16 -0
  34. data/test/dummy/config/initializers/mime_types.rb +5 -0
  35. data/test/dummy/config/initializers/secret_token.rb +12 -0
  36. data/test/dummy/config/initializers/session_store.rb +3 -0
  37. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  38. data/test/dummy/config/locales/en.yml +23 -0
  39. data/test/dummy/config/routes.rb +56 -0
  40. data/test/dummy/config.ru +4 -0
  41. data/test/dummy/db/development.sqlite3 +0 -0
  42. data/test/dummy/db/migrate/20131023212242_create_users.rb +10 -0
  43. data/test/dummy/db/schema.rb +23 -0
  44. data/test/dummy/log/development.log +24 -0
  45. data/test/dummy/public/404.html +58 -0
  46. data/test/dummy/public/422.html +58 -0
  47. data/test/dummy/public/500.html +57 -0
  48. data/test/dummy/public/favicon.ico +0 -0
  49. data/test/dummy/test/fixtures/users.yml +9 -0
  50. data/test/dummy/test/models/user_test.rb +7 -0
  51. data/test/rails_attr_enum_test.rb +7 -0
  52. data/test/test_helper.rb +15 -0
  53. metadata +162 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: e50e904586e33747717a8578df7a9ba7b6ca4d9b
4
+ data.tar.gz: c5b49a433cf04cd9ba9008e67236d9c6c71bb9ea
5
+ SHA512:
6
+ metadata.gz: 3ab5f0e629717b89d5e5b25bc62abd9d3049a37c7581c8db12657368e63f24042a04045b996610e6927ddaf6c092e84f69ea5d8bafd4c2863706abb76ce64e5c
7
+ data.tar.gz: 4bda9c9c484c99d659683be72a0e70e8d2797a35d0b5d0c6a4b3a38ee21619fddba73fd904aa2ee924aa1510d74668aa6235e48b4585e93746541b3919dff2fd
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2013 Jeremy Fairbank
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy of
6
+ this software and associated documentation files (the "Software"), to deal in
7
+ the Software without restriction, including without limitation the rights to
8
+ use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
9
+ the Software, and to permit persons to whom the Software is furnished to do so,
10
+ subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
17
+ FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
18
+ COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
19
+ IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
20
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.rdoc ADDED
@@ -0,0 +1,3 @@
1
+ = RailsAttrEnum
2
+
3
+ This project rocks and uses MIT-LICENSE.
data/Rakefile ADDED
@@ -0,0 +1,32 @@
1
+ begin
2
+ require 'bundler/setup'
3
+ rescue LoadError
4
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
5
+ end
6
+
7
+ require 'rdoc/task'
8
+
9
+ RDoc::Task.new(:rdoc) do |rdoc|
10
+ rdoc.rdoc_dir = 'rdoc'
11
+ rdoc.title = 'RailsAttrEnum'
12
+ rdoc.options << '--line-numbers'
13
+ rdoc.rdoc_files.include('README.rdoc')
14
+ rdoc.rdoc_files.include('lib/**/*.rb')
15
+ end
16
+
17
+
18
+
19
+
20
+ Bundler::GemHelper.install_tasks
21
+
22
+ require 'rake/testtask'
23
+
24
+ Rake::TestTask.new(:test) do |t|
25
+ t.libs << 'lib'
26
+ t.libs << 'test'
27
+ t.pattern = 'test/**/*_test.rb'
28
+ t.verbose = false
29
+ end
30
+
31
+
32
+ task default: :test
@@ -0,0 +1,11 @@
1
+ module RailsAttrEnum
2
+ ## Represent an attribute
3
+ class Attr
4
+ attr_reader :name, :enum_name
5
+
6
+ def initialize(name)
7
+ @name = name.to_s
8
+ @enum_name = @name.camelize
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,6 @@
1
+ require 'ostruct'
2
+
3
+ module RailsAttrEnum
4
+ ## Enum entry class
5
+ Entry = Struct.new(:key, :value, :label)
6
+ end
@@ -0,0 +1,44 @@
1
+ require 'ostruct'
2
+
3
+ module RailsAttrEnum
4
+ ## Forwarding class for actual attribute value
5
+ EntryValue = Struct.new(:model, :attr_name, :enum) do
6
+ delegate :==, :===, :inspect, to: :value
7
+
8
+ def method_missing(name, *args, &block)
9
+ default = proc { value.send(name, *args, &block) }
10
+
11
+ if matches = /^(.*?)((\?|!)?)$/.match(name)
12
+ const_name = matches[1].to_s.upcase
13
+ if enum.const_defined?(const_name)
14
+ case matches[2]
15
+ when '?'
16
+ value == enum.const_get(const_name)
17
+ when '!'
18
+ self.value = enum.const_get(const_name)
19
+ else
20
+ enum.const_get(const_name)
21
+ end
22
+ else
23
+ default.call
24
+ end
25
+ else
26
+ default.call
27
+ end
28
+ end
29
+
30
+ def key
31
+ enum.get_key(value)
32
+ end
33
+
34
+ def value
35
+ model.read_attribute(attr_name)
36
+ end
37
+
38
+ private
39
+
40
+ def value=(v)
41
+ model.send(:write_attribute, attr_name, v)
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,53 @@
1
+ module RailsAttrEnum
2
+
3
+ ## Enum representation
4
+ module Enum
5
+ def self.included(base)
6
+ base.extend ClassMethods
7
+ end
8
+
9
+ module ClassMethods
10
+ def init_enum(attr_name)
11
+ return if @init
12
+ @attr_name = attr_name
13
+ @entries = []
14
+ @init = true
15
+ end
16
+
17
+ def add(entry)
18
+ const_name = entry[:key].to_s.upcase
19
+ const_set(const_name, entry[:value])
20
+ const_set("#{const_name}_LABEL", entry[:label])
21
+ @entries << entry
22
+ end
23
+
24
+ def label_value_pairs
25
+ labels.zip values
26
+ end
27
+
28
+ def get_label(value)
29
+ get_from_entries(:label, value)
30
+ end
31
+
32
+ def get_key(value)
33
+ get_from_entries(:key, value)
34
+ end
35
+
36
+ def attr_name; @attr_name end
37
+ def keys; mapped(:key) end
38
+ def values; mapped(:value) end
39
+ def labels; mapped(:label) end
40
+
41
+ private
42
+
43
+ def get_from_entries(key, value)
44
+ @entries.find { |hash| hash[:value] == value }.try(:[], key)
45
+ end
46
+
47
+ def mapped(key)
48
+ @entries.map { |hash| hash[key] }
49
+ end
50
+ end
51
+ end
52
+
53
+ end
@@ -0,0 +1,81 @@
1
+ require 'set'
2
+
3
+ module RailsAttrEnum
4
+
5
+ ## Class to build up enum values
6
+ class EnumAccumulator
7
+ attr_reader :entries, :validation_rules
8
+
9
+ def initialize
10
+ @entries = []
11
+ @validation_rules = {}
12
+ @values = SortedSet.new
13
+ end
14
+
15
+ def add(key)
16
+ if key.is_a?(Hash)
17
+ key, value = key.first
18
+
19
+ case value
20
+ when String
21
+ label = value
22
+ value = next_free_value
23
+ when Hash
24
+ label = value[:label] || key.to_s.titleize
25
+ value = value[:value] || next_free_value
26
+ when Numeric
27
+ label = key.to_s.titleize
28
+ end
29
+ else
30
+ value = next_free_value
31
+ label = key.to_s.titleize
32
+ end
33
+
34
+ add_entry(key, value, label)
35
+ end
36
+
37
+ def validates(rules = {})
38
+ @validation_rules = rules
39
+ end
40
+
41
+ private
42
+
43
+ def add_entry(key, value, label)
44
+ Entry.new(key, value, label).tap do |entry|
45
+ revalue_entries!(value)
46
+ @entries << entry
47
+ @values << value
48
+ end
49
+ end
50
+
51
+ def revalue_entries!(value)
52
+ @entries.each do |entry|
53
+ if entry.value == value
54
+ entry.value = next_free_value!
55
+ end
56
+ end
57
+ end
58
+
59
+ def next_free_value
60
+ counter = 0
61
+ value =
62
+ if @values.empty?
63
+ 0
64
+ else
65
+ @values.each do |v|
66
+ next if v < 0
67
+ break if v != counter
68
+ counter += 1
69
+ end
70
+ counter
71
+ end
72
+
73
+ value
74
+ end
75
+
76
+ def next_free_value!
77
+ next_free_value.tap { |v| @values << v }
78
+ end
79
+ end
80
+
81
+ end
@@ -0,0 +1,3 @@
1
+ module RailsAttrEnum
2
+ VERSION = '0.0.2'
3
+ end
@@ -0,0 +1,98 @@
1
+ module RailsAttrEnum
2
+
3
+ autoload :Attr, 'rails_attr_enum/attr.rb'
4
+ autoload :Entry, 'rails_attr_enum/entry.rb'
5
+ autoload :EntryValue, 'rails_attr_enum/entry_value.rb'
6
+ autoload :Enum, 'rails_attr_enum/enum.rb'
7
+ autoload :EnumAccumulator, 'rails_attr_enum/enum_accumulator.rb'
8
+ autoload :Version, 'rails_attr_enum/version.rb'
9
+
10
+ def attr_enum(attr_name, *keys, &block)
11
+ if block_given?
12
+ add_attr_enum_through_block(attr_name, &block)
13
+ else
14
+ if keys.first.is_a?(Hash)
15
+ add_attr_enum_through_block(attr_name) do
16
+ keys.first.each { |k, v| add k => v }
17
+ end
18
+ else
19
+ add_attr_enum_through_block(attr_name) do
20
+ keys.each { |k| add k }
21
+ end
22
+ end
23
+ end
24
+
25
+ nil
26
+ end
27
+
28
+ private
29
+
30
+ def add_attr_enum(attr_name, entries, validation_rules)
31
+ attr = Attr.new(attr_name)
32
+
33
+ @_attr_enums ||= {}
34
+
35
+ unless column_names.include?(attr.name)
36
+ raise "Invalid attribute name #{attr_name_s}"
37
+ end
38
+
39
+ if @_attr_enums.any? { |(_, enm)| enm.attr_name == attr.name }
40
+ raise "Already defined enum for '#{attr_name_s}'"
41
+ end
42
+
43
+ @_attr_enums[attr.name.to_sym] = Module.new { include Enum }.tap do |mod|
44
+ mod.init_enum(attr.name)
45
+ entries.each(&mod.method(:add))
46
+ const_set(attr.enum_name, mod)
47
+ class_eval do
48
+ validates(attr.name.to_sym, validation_rules.merge(inclusion: { in: mod.values }))
49
+ end
50
+ end
51
+
52
+ add_methods(attr)
53
+ end
54
+
55
+ def add_attr_enum_through_block(attr_name, &block)
56
+ acc = EnumAccumulator.new
57
+ acc.instance_eval(&block)
58
+ add_attr_enum(attr_name, acc.entries, acc.validation_rules)
59
+ end
60
+
61
+ # def add_attr_display_method(attr)
62
+ def add_methods(attr)
63
+ class_eval <<-EOS, __FILE__, __LINE__ + 1
64
+ # Add the display method like 'display_status' for attribute 'status'
65
+ def display_#{attr.name}
66
+ value = read_attribute(:#{attr.name})
67
+ return '' if value.nil?
68
+ self.class.instance_variable_get(:@_attr_enums)[:#{attr.name}].get_label(value)
69
+ end
70
+
71
+ # Add method like 'status?' for attribute 'status'
72
+ def #{attr.name}?(key = nil)
73
+ if key.nil?
74
+ !read_attribute(:#{attr.name}).nil?
75
+ else
76
+ read_attribute(:#{attr.name}) == #{attr.enum_name}.const_get(key.to_s.upcase)
77
+ end
78
+ end
79
+
80
+ # Override the attr= method
81
+ def #{attr.name}=(key)
82
+ if key.is_a? Symbol
83
+ #{attr.enum_name}.const_get(key.to_s.upcase).tap do |value|
84
+ write_attribute(:#{attr.name}, value)
85
+ end
86
+ else
87
+ super
88
+ end
89
+ end
90
+
91
+ # Override the attr method
92
+ def #{attr.name}
93
+ EntryValue.new(self, :#{attr.name}, #{attr.enum_name})
94
+ end
95
+ EOS
96
+ end
97
+
98
+ end
@@ -0,0 +1,4 @@
1
+ # desc "Explaining what the task does"
2
+ # task :rails_attr_enum do
3
+ # # Task goes here
4
+ # end
@@ -0,0 +1,28 @@
1
+ == README
2
+
3
+ This README would normally document whatever steps are necessary to get the
4
+ application up and running.
5
+
6
+ Things you may want to cover:
7
+
8
+ * Ruby version
9
+
10
+ * System dependencies
11
+
12
+ * Configuration
13
+
14
+ * Database creation
15
+
16
+ * Database initialization
17
+
18
+ * How to run the test suite
19
+
20
+ * Services (job queues, cache servers, search engines, etc.)
21
+
22
+ * Deployment instructions
23
+
24
+ * ...
25
+
26
+
27
+ Please feel free to use a different markup language if you do not plan to run
28
+ <tt>rake doc:app</tt>.
@@ -0,0 +1,6 @@
1
+ # Add your own tasks in files placed in lib/tasks ending in .rake,
2
+ # for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
3
+
4
+ require File.expand_path('../config/application', __FILE__)
5
+
6
+ Dummy::Application.load_tasks
@@ -0,0 +1,13 @@
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 vendor/assets/javascripts of plugins, if any, 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.
9
+ //
10
+ // Read Sprockets README (https://github.com/sstephenson/sprockets#sprockets-directives) for details
11
+ // about supported directives.
12
+ //
13
+ //= require_tree .
@@ -0,0 +1,13 @@
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 vendor/assets/stylesheets of plugins, if any, 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 top of the
9
+ * compiled file, but it's generally better to create a new file per style scope.
10
+ *
11
+ *= require_self
12
+ *= require_tree .
13
+ */
@@ -0,0 +1,5 @@
1
+ class ApplicationController < ActionController::Base
2
+ # Prevent CSRF attacks by raising an exception.
3
+ # For APIs, you may want to use :null_session instead.
4
+ protect_from_forgery with: :exception
5
+ end
@@ -0,0 +1,2 @@
1
+ module ApplicationHelper
2
+ end
@@ -0,0 +1,5 @@
1
+ class User < ActiveRecord::Base
2
+ extend RailsAttrEnum
3
+
4
+ attr_enum :role, :admin, :author, :editor
5
+ end
@@ -0,0 +1,14 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Dummy</title>
5
+ <%= stylesheet_link_tag "application", media: "all", "data-turbolinks-track" => true %>
6
+ <%= javascript_include_tag "application", "data-turbolinks-track" => true %>
7
+ <%= csrf_meta_tags %>
8
+ </head>
9
+ <body>
10
+
11
+ <%= yield %>
12
+
13
+ </body>
14
+ </html>
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env ruby
2
+ ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__)
3
+ load Gem.bin_path('bundler', 'bundle')
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+ APP_PATH = File.expand_path('../../config/application', __FILE__)
3
+ require_relative '../config/boot'
4
+ require 'rails/commands'
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+ require_relative '../config/boot'
3
+ require 'rake'
4
+ Rake.application.run
@@ -0,0 +1,23 @@
1
+ require File.expand_path('../boot', __FILE__)
2
+
3
+ require 'rails/all'
4
+
5
+ Bundler.require(*Rails.groups)
6
+ require "rails_attr_enum"
7
+
8
+ module Dummy
9
+ class Application < Rails::Application
10
+ # Settings in config/environments/* take precedence over those specified here.
11
+ # Application configuration should go into files in config/initializers
12
+ # -- all .rb files in that directory are automatically loaded.
13
+
14
+ # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
15
+ # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
16
+ # config.time_zone = 'Central Time (US & Canada)'
17
+
18
+ # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
19
+ # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
20
+ # config.i18n.default_locale = :de
21
+ end
22
+ end
23
+
@@ -0,0 +1,5 @@
1
+ # Set up gems listed in the Gemfile.
2
+ ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../../../Gemfile', __FILE__)
3
+
4
+ require 'bundler/setup' if File.exists?(ENV['BUNDLE_GEMFILE'])
5
+ $LOAD_PATH.unshift File.expand_path('../../../../lib', __FILE__)
@@ -0,0 +1,25 @@
1
+ # SQLite version 3.x
2
+ # gem install sqlite3
3
+ #
4
+ # Ensure the SQLite 3 gem is defined in your Gemfile
5
+ # gem 'sqlite3'
6
+ development:
7
+ adapter: sqlite3
8
+ database: db/development.sqlite3
9
+ pool: 5
10
+ timeout: 5000
11
+
12
+ # Warning: The database defined as "test" will be erased and
13
+ # re-generated from your development database when you run "rake".
14
+ # Do not set this db to the same as development or production.
15
+ test:
16
+ adapter: sqlite3
17
+ database: db/test.sqlite3
18
+ pool: 5
19
+ timeout: 5000
20
+
21
+ production:
22
+ adapter: sqlite3
23
+ database: db/production.sqlite3
24
+ pool: 5
25
+ timeout: 5000
@@ -0,0 +1,5 @@
1
+ # Load the Rails application.
2
+ require File.expand_path('../application', __FILE__)
3
+
4
+ # Initialize the Rails application.
5
+ Dummy::Application.initialize!
@@ -0,0 +1,29 @@
1
+ Dummy::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 and disable caching.
13
+ config.consider_all_requests_local = true
14
+ config.action_controller.perform_caching = false
15
+
16
+ # Don't care if the mailer can't send.
17
+ config.action_mailer.raise_delivery_errors = false
18
+
19
+ # Print deprecation notices to the Rails logger.
20
+ config.active_support.deprecation = :log
21
+
22
+ # Raise an error on page load if there are pending migrations
23
+ config.active_record.migration_error = :page_load
24
+
25
+ # Debug mode disables concatenation and preprocessing of assets.
26
+ # This option may cause significant delays in view rendering with a large
27
+ # number of complex assets.
28
+ config.assets.debug = true
29
+ end
@@ -0,0 +1,80 @@
1
+ Dummy::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 thread 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
+ # Enable Rack::Cache to put a simple HTTP cache in front of your application
18
+ # Add `rack-cache` to your Gemfile before enabling this.
19
+ # For large-scale production use, consider using a caching reverse proxy like nginx, varnish or squid.
20
+ # config.action_dispatch.rack_cache = true
21
+
22
+ # Disable Rails's static asset server (Apache or nginx will already do this).
23
+ config.serve_static_assets = false
24
+
25
+ # Compress JavaScripts and CSS.
26
+ config.assets.js_compressor = :uglifier
27
+ # config.assets.css_compressor = :sass
28
+
29
+ # Do not fallback to assets pipeline if a precompiled asset is missed.
30
+ config.assets.compile = false
31
+
32
+ # Generate digests for assets URLs.
33
+ config.assets.digest = true
34
+
35
+ # Version of your assets, change this if you want to expire all your assets.
36
+ config.assets.version = '1.0'
37
+
38
+ # Specifies the header that your server uses for sending files.
39
+ # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
40
+ # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
41
+
42
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
43
+ # config.force_ssl = true
44
+
45
+ # Set to :debug to see everything in the log.
46
+ config.log_level = :info
47
+
48
+ # Prepend all log lines with the following tags.
49
+ # config.log_tags = [ :subdomain, :uuid ]
50
+
51
+ # Use a different logger for distributed setups.
52
+ # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
53
+
54
+ # Use a different cache store in production.
55
+ # config.cache_store = :mem_cache_store
56
+
57
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server.
58
+ # config.action_controller.asset_host = "http://assets.example.com"
59
+
60
+ # Precompile additional assets.
61
+ # application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
62
+ # config.assets.precompile += %w( search.js )
63
+
64
+ # Ignore bad email addresses and do not raise email delivery errors.
65
+ # Set this to true and configure the email server for immediate delivery to raise delivery errors.
66
+ # config.action_mailer.raise_delivery_errors = false
67
+
68
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
69
+ # the I18n.default_locale when a translation can not be found).
70
+ config.i18n.fallbacks = true
71
+
72
+ # Send deprecation notices to registered listeners.
73
+ config.active_support.deprecation = :notify
74
+
75
+ # Disable automatic flushing of the log to improve performance.
76
+ # config.autoflush_log = false
77
+
78
+ # Use default logging formatter so that PID and timestamp are not suppressed.
79
+ config.log_formatter = ::Logger::Formatter.new
80
+ end