Class: CopyTunerClient::Cache
- Inherits:
-
Object
- Object
- CopyTunerClient::Cache
- Defined in:
- lib/copy_tuner_client/cache.rb
Overview
Manages synchronization of copy between I18nBackend and Client. Acts like a Hash. Applications using the client will not need to interact with this class directly.
Responsible for locking down access to data used by both threads.
Constant Summary collapse
- STATUS_NOT_READY =
:not_ready
- STATUS_PENDING =
:pending
- STATUS_READY =
:ready
Instance Attribute Summary collapse
-
#blurbs ⇒ Object
readonly
Returns the value of attribute blurbs.
-
#last_downloaded_at ⇒ Object
readonly
Returns the value of attribute last_downloaded_at.
-
#last_uploaded_at ⇒ Object
readonly
Returns the value of attribute last_uploaded_at.
-
#queued ⇒ Object
readonly
Returns the value of attribute queued.
Instance Method Summary collapse
-
#[](key) ⇒ String
Returns content for the given blurb.
-
#[]=(key, value) ⇒ Object
Sets content for the given blurb.
- #download ⇒ Object
-
#export ⇒ String
Yaml representation of all blurbs.
- #flush ⇒ Object
-
#initialize(client, options) ⇒ Cache
constructor
Usually instantiated when CopyTunerClient::Configuration#apply is invoked.
- #inspect ⇒ Object
-
#keys ⇒ Array<String>
Keys for all blurbs stored on the server.
- #pending? ⇒ Boolean
- #ready? ⇒ Boolean
-
#sync ⇒ Object
Downloads and then flushes.
-
#to_tree_hash ⇒ Hash
ツリー構造のハッシュを返す(I18nBackend用).
-
#version ⇒ String?
キャッシュの更新バージョンを返す(ツリーキャッシュの無効化判定用) ETags を使用してサーバーサイドの更新を検知.
-
#wait_for_download ⇒ Object
Waits until the first download has finished.
Constructor Details
#initialize(client, options) ⇒ Cache
Usually instantiated when CopyTunerClient::Configuration#apply is invoked.
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/copy_tuner_client/cache.rb', line 19 def initialize(client, ) @client = client @logger = [:logger] @mutex = Mutex.new @exclude_key_regexp = [:exclude_key_regexp] @upload_disabled = [:upload_disabled] @ignored_keys = .fetch(:ignored_keys, []) @ignored_key_handler = .fetch(:ignored_key_handler, -> (e) { raise e }) @locales = Array([:locales]).map(&:to_s) # mutable states @blurbs = {} @blank_keys = Set.new @queued = {} @status = STATUS_NOT_READY end |
Instance Attribute Details
#blurbs ⇒ Object (readonly)
Returns the value of attribute blurbs.
142 143 144 |
# File 'lib/copy_tuner_client/cache.rb', line 142 def blurbs @blurbs end |
#last_downloaded_at ⇒ Object (readonly)
Returns the value of attribute last_downloaded_at.
142 143 144 |
# File 'lib/copy_tuner_client/cache.rb', line 142 def last_downloaded_at @last_downloaded_at end |
#last_uploaded_at ⇒ Object (readonly)
Returns the value of attribute last_uploaded_at.
142 143 144 |
# File 'lib/copy_tuner_client/cache.rb', line 142 def last_uploaded_at @last_uploaded_at end |
#queued ⇒ Object (readonly)
Returns the value of attribute queued.
142 143 144 |
# File 'lib/copy_tuner_client/cache.rb', line 142 def queued @queued end |
Instance Method Details
#[](key) ⇒ String
Returns content for the given blurb.
38 39 40 |
# File 'lib/copy_tuner_client/cache.rb', line 38 def [](key) lock { @blurbs[key] } end |
#[]=(key, value) ⇒ Object
Sets content for the given blurb. The content will be pushed to the server on the next flush.
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'lib/copy_tuner_client/cache.rb', line 46 def []=(key, value) return if @exclude_key_regexp && key.match?(@exclude_key_regexp) return unless key.include?('.') return if @locales.present? && !@locales.member?(key.split('.').first) return if @upload_disabled # NOTE: config/locales以下のファイルに除外キーが残っていた場合の対応 key_without_locale = key.split('.')[1..].join('.') if @ignored_keys.include?(key_without_locale) @ignored_key_handler.call(IgnoredKey.new("Ignored key: #{key_without_locale}")) end lock do return if @blank_keys.member?(key) || @blurbs.key?(key) @queued[key] = value end end |
#download ⇒ Object
116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 |
# File 'lib/copy_tuner_client/cache.rb', line 116 def download @status = STATUS_PENDING unless ready? res = client.download(cache_fallback: pending?) do |downloaded_blurbs| blank_blurbs, blurbs = downloaded_blurbs.partition { |_key, value| value == '' } lock do @blank_keys = Set.new(blank_blurbs.map(&:first)) @blurbs = blurbs.to_h end end @last_downloaded_at = Time.now.utc @status = STATUS_READY unless ready? res rescue ConnectionError => e logger.error e. raise e unless ready? end |
#export ⇒ String
Yaml representation of all blurbs
73 74 75 76 |
# File 'lib/copy_tuner_client/cache.rb', line 73 def export tree_hash = to_tree_hash tree_hash.present? ? tree_hash.to_yaml : nil end |
#flush ⇒ Object
104 105 106 107 108 109 110 111 112 113 114 |
# File 'lib/copy_tuner_client/cache.rb', line 104 def flush res = with_queued_changes do |queued| client.upload queued end @last_uploaded_at = Time.now.utc res rescue ConnectionError => e logger.error e. end |
#inspect ⇒ Object
144 145 146 |
# File 'lib/copy_tuner_client/cache.rb', line 144 def inspect "#<CopyTunerClient::Cache:#{object_id}>" end |
#keys ⇒ Array<String>
Keys for all blurbs stored on the server.
67 68 69 |
# File 'lib/copy_tuner_client/cache.rb', line 67 def keys lock { @blurbs.keys } end |
#pending? ⇒ Boolean
148 149 150 |
# File 'lib/copy_tuner_client/cache.rb', line 148 def pending? @status == STATUS_PENDING end |
#ready? ⇒ Boolean
152 153 154 |
# File 'lib/copy_tuner_client/cache.rb', line 152 def ready? @status == STATUS_READY end |
#sync ⇒ Object
Downloads and then flushes
137 138 139 140 |
# File 'lib/copy_tuner_client/cache.rb', line 137 def sync download flush end |
#to_tree_hash ⇒ Hash
ツリー構造のハッシュを返す(I18nBackend用)
80 81 82 |
# File 'lib/copy_tuner_client/cache.rb', line 80 def to_tree_hash lock { @blurbs.present? ? DottedHash.to_h(@blurbs) : {} } end |
#version ⇒ String?
キャッシュの更新バージョンを返す(ツリーキャッシュの無効化判定用)ETags を使用してサーバーサイドの更新を検知
87 88 89 |
# File 'lib/copy_tuner_client/cache.rb', line 87 def version client.etag end |
#wait_for_download ⇒ Object
Waits until the first download has finished.
92 93 94 95 96 97 98 99 100 101 102 |
# File 'lib/copy_tuner_client/cache.rb', line 92 def wait_for_download return unless pending? logger.info 'Waiting for first download' if logger.respond_to? :flush logger.flush end sleep 0.1 while pending? end |