|
|
@ -103,12 +103,8 @@ class ApplicationController < ActionController::Base |
|
|
|
return raw unless klass.respond_to?(:with_includes) |
|
|
|
return raw unless klass.respond_to?(:with_includes) |
|
|
|
|
|
|
|
|
|
|
|
raw = raw.cache_ids.to_a if raw.is_a?(ActiveRecord::Relation) |
|
|
|
raw = raw.cache_ids.to_a if raw.is_a?(ActiveRecord::Relation) |
|
|
|
uncached_ids = [] |
|
|
|
cached_keys_with_value = Rails.cache.read_multi(*raw).transform_keys(&:id) |
|
|
|
cached_keys_with_value = Rails.cache.read_multi(*raw.map(&:cache_key)) |
|
|
|
uncached_ids = raw.map(&:id) - cached_keys_with_value.keys |
|
|
|
|
|
|
|
|
|
|
|
raw.each do |item| |
|
|
|
|
|
|
|
uncached_ids << item.id unless cached_keys_with_value.key?(item.cache_key) |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
klass.reload_stale_associations!(cached_keys_with_value.values) if klass.respond_to?(:reload_stale_associations!) |
|
|
|
klass.reload_stale_associations!(cached_keys_with_value.values) if klass.respond_to?(:reload_stale_associations!) |
|
|
|
|
|
|
|
|
|
|
@ -116,11 +112,11 @@ class ApplicationController < ActionController::Base |
|
|
|
uncached = klass.where(id: uncached_ids).with_includes.map { |item| [item.id, item] }.to_h |
|
|
|
uncached = klass.where(id: uncached_ids).with_includes.map { |item| [item.id, item] }.to_h |
|
|
|
|
|
|
|
|
|
|
|
uncached.each_value do |item| |
|
|
|
uncached.each_value do |item| |
|
|
|
Rails.cache.write(item.cache_key, item) |
|
|
|
Rails.cache.write(item, item) |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
raw.map { |item| cached_keys_with_value[item.cache_key] || uncached[item.id] }.compact |
|
|
|
raw.map { |item| cached_keys_with_value[item.id] || uncached[item.id] }.compact |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
def respond_with_error(code) |
|
|
|
def respond_with_error(code) |
|
|
@ -135,7 +131,6 @@ class ApplicationController < ActionController::Base |
|
|
|
|
|
|
|
|
|
|
|
def render_cached_json(cache_key, **options) |
|
|
|
def render_cached_json(cache_key, **options) |
|
|
|
options[:expires_in] ||= 3.minutes |
|
|
|
options[:expires_in] ||= 3.minutes |
|
|
|
cache_key = cache_key.join(':') if cache_key.is_a?(Enumerable) |
|
|
|
|
|
|
|
cache_public = options.key?(:public) ? options.delete(:public) : true |
|
|
|
cache_public = options.key?(:public) ? options.delete(:public) : true |
|
|
|
content_type = options.delete(:content_type) || 'application/json' |
|
|
|
content_type = options.delete(:content_type) || 'application/json' |
|
|
|
|
|
|
|
|
|
|
|