2019-07-02 08:10:25 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'singleton'
|
|
|
|
|
|
|
|
class EntityCache
|
|
|
|
include Singleton
|
|
|
|
|
|
|
|
MAX_EXPIRATION = 7.days.freeze
|
|
|
|
|
|
|
|
def mention(username, domain)
|
2020-11-15 18:48:32 +00:00
|
|
|
Rails.cache.fetch(to_key(:mention, username, domain), expires_in: MAX_EXPIRATION) { Account.select(:username, :domain, :url).find_local(username) }
|
2019-07-02 08:10:25 +01:00
|
|
|
end
|
|
|
|
|
2020-12-04 03:27:09 +00:00
|
|
|
def emoji(shortcodes, domain = nil)
|
2019-07-02 08:10:25 +01:00
|
|
|
shortcodes = [shortcodes] unless shortcodes.is_a?(Array)
|
|
|
|
cached = Rails.cache.read_multi(*shortcodes.map { |shortcode| to_key(:emoji, shortcode, domain) })
|
|
|
|
uncached_ids = []
|
|
|
|
|
|
|
|
shortcodes.each do |shortcode|
|
|
|
|
uncached_ids << shortcode unless cached.key?(to_key(:emoji, shortcode, domain))
|
|
|
|
end
|
|
|
|
|
|
|
|
unless uncached_ids.empty?
|
2020-12-03 04:22:51 +00:00
|
|
|
uncached = CustomEmoji.where(shortcode: shortcodes, domain: domain).each_with_object({}) { |item, h| h[item.shortcode] = item }
|
2019-07-02 08:10:25 +01:00
|
|
|
uncached.each_value { |item| Rails.cache.write(to_key(:emoji, item.shortcode, domain), item, expires_in: MAX_EXPIRATION) }
|
|
|
|
end
|
|
|
|
|
|
|
|
shortcodes.map { |shortcode| cached[to_key(:emoji, shortcode, domain)] || uncached[shortcode] }.compact
|
|
|
|
end
|
|
|
|
|
|
|
|
def to_key(type, *ids)
|
|
|
|
"#{type}:#{ids.compact.map(&:downcase).join(':')}"
|
|
|
|
end
|
|
|
|
end
|