Extend rails-settings-cached to merge db-saved hash values with defaults

This commit is contained in:
Eugen Rochko
2017-01-13 02:42:22 +01:00
parent ca50ceeaf0
commit 2939e9898b
6 changed files with 44 additions and 70 deletions

View File

@ -96,7 +96,7 @@ class Api::V1::AccountsController < ApiController
limit = params[:limit] ? [DEFAULT_ACCOUNTS_LIMIT, params[:limit].to_i].min : DEFAULT_ACCOUNTS_LIMIT
@accounts = SearchService.new.call(params[:q], limit, params[:resolve] == 'true')
set_account_counters_maps(@accounts)
set_account_counters_maps(@accounts) unless @accounts.nil?
render action: :index
end

View File

@ -0,0 +1,9 @@
module Settings
module Extend
extend ActiveSupport::Concern
def settings
ScopedSettings.for_thing(self)
end
end
end

View File

@ -0,0 +1,12 @@
module Settings
class ScopedSettings < ::Setting
def self.for_thing(object)
@object = object
self
end
def self.thing_scoped
unscoped.where(thing_type: @object.class.base_class.to_s, thing_id: @object.id)
end
end
end

View File

@ -9,6 +9,26 @@ class Setting < RailsSettings::Base
end
class << self
def [](key)
return super(key) unless rails_initialized?
val = Rails.cache.fetch(cache_key(key, @object)) do
db_val = object(key)
if db_val
default_value = default_settings[key]
return default_value.with_indifferent_access.merge!(db_val.value) if default_value.is_a?(Hash)
db_val.value
else
default_settings[key]
end
end
val
end
def all_as_records
vars = thing_scoped
records = vars.map { |r| [r.var, r] }.to_h

View File

@ -1,7 +1,7 @@
# frozen_string_literal: true
class User < ApplicationRecord
include RailsSettings::Extend
include Settings::Extend
devise :database_authenticatable, :registerable, :recoverable, :rememberable, :trackable, :validatable, :confirmable