Refactor Setting (#3302)

* @object is not needed

* Remove unneeded dependencies

* Do not call private method

* Prefer #respond_to_missing? over #respond_to?

`#respond_to?` doesn't support `User.settings.method(:method_name)`

* Use find_or_initialize_by instead of
master
alpaca-tc 7 years ago committed by Eugen Rochko
parent 2469fd1cdc
commit 08dce5e607
  1. 2
      app/lib/settings/extend.rb
  2. 13
      app/lib/settings/scoped_settings.rb
  3. 4
      app/models/setting.rb

@ -2,8 +2,6 @@
module Settings module Settings
module Extend module Extend
extend ActiveSupport::Concern
def settings def settings
@settings ||= ScopedSettings.new(self) @settings ||= ScopedSettings.new(self)
end end

@ -21,7 +21,7 @@ module Settings
end end
# rubocop:enable Style/MethodMissing # rubocop:enable Style/MethodMissing
def respond_to?(_method_name, _include_private = false) def respond_to_missing?(*)
true true
end end
@ -29,7 +29,7 @@ module Settings
vars = thing_scoped vars = thing_scoped
records = vars.map { |r| [r.var, r] }.to_h records = vars.map { |r| [r.var, r] }.to_h
Setting.send(:default_settings).each do |key, default_value| Setting.default_settings.each do |key, default_value|
next if records.key?(key) || default_value.is_a?(Hash) next if records.key?(key) || default_value.is_a?(Hash)
records[key] = Setting.new(var: key, value: default_value) records[key] = Setting.new(var: key, value: default_value)
end end
@ -39,9 +39,8 @@ module Settings
def []=(key, value) def []=(key, value)
key = key.to_s key = key.to_s
record = thing_scoped.find_by(var: key) || thing_scoped.new(var: key) record = thing_scoped.find_or_initialize_by(var: key)
record.value = value record.update!(value: value)
record.save!
Rails.cache.write(Setting.cache_key(key, @object), value) Rails.cache.write(Setting.cache_key(key, @object), value)
value value
@ -51,11 +50,11 @@ module Settings
Rails.cache.fetch(Setting.cache_key(key, @object)) do Rails.cache.fetch(Setting.cache_key(key, @object)) do
db_val = thing_scoped.find_by(var: key.to_s) db_val = thing_scoped.find_by(var: key.to_s)
if db_val if db_val
default_value = Setting.send(:default_settings)[key] default_value = Setting.default_settings[key]
return default_value.with_indifferent_access.merge!(db_val.value) if default_value.is_a?(Hash) return default_value.with_indifferent_access.merge!(db_val.value) if default_value.is_a?(Hash)
db_val.value db_val.value
else else
Setting.send(:default_settings)[key] Setting.default_settings[key]
end end
end end
end end

@ -23,7 +23,7 @@ class Setting < RailsSettings::Base
def [](key) def [](key)
return super(key) unless rails_initialized? return super(key) unless rails_initialized?
val = Rails.cache.fetch(cache_key(key, @object)) do val = Rails.cache.fetch(cache_key(key, nil)) do
db_val = object(key) db_val = object(key)
if db_val if db_val
@ -50,8 +50,6 @@ class Setting < RailsSettings::Base
records records
end end
private
def default_settings def default_settings
return {} unless RailsSettings::Default.enabled? return {} unless RailsSettings::Default.enabled?
RailsSettings::Default.instance RailsSettings::Default.instance

Loading…
Cancel
Save