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.
-
#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.
128 129 130 |
# File 'lib/copy_tuner_client/cache.rb', line 128 def blurbs @blurbs end |
#last_downloaded_at ⇒ Object (readonly)
Returns the value of attribute last_downloaded_at.
128 129 130 |
# File 'lib/copy_tuner_client/cache.rb', line 128 def last_downloaded_at @last_downloaded_at end |
#last_uploaded_at ⇒ Object (readonly)
Returns the value of attribute last_uploaded_at.
128 129 130 |
# File 'lib/copy_tuner_client/cache.rb', line 128 def last_uploaded_at @last_uploaded_at end |
#queued ⇒ Object (readonly)
Returns the value of attribute queued.
128 129 130 |
# File 'lib/copy_tuner_client/cache.rb', line 128 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
102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 |
# File 'lib/copy_tuner_client/cache.rb', line 102 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 |
# File 'lib/copy_tuner_client/cache.rb', line 73 def export lock { @blurbs.present? ? DottedHash.to_h(@blurbs).to_yaml : nil } end |
#flush ⇒ Object
90 91 92 93 94 95 96 97 98 99 100 |
# File 'lib/copy_tuner_client/cache.rb', line 90 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
130 131 132 |
# File 'lib/copy_tuner_client/cache.rb', line 130 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
134 135 136 |
# File 'lib/copy_tuner_client/cache.rb', line 134 def pending? @status == STATUS_PENDING end |
#ready? ⇒ Boolean
138 139 140 |
# File 'lib/copy_tuner_client/cache.rb', line 138 def ready? @status == STATUS_READY end |
#sync ⇒ Object
Downloads and then flushes
123 124 125 126 |
# File 'lib/copy_tuner_client/cache.rb', line 123 def sync download flush end |
#wait_for_download ⇒ Object
Waits until the first download has finished.
78 79 80 81 82 83 84 85 86 87 88 |
# File 'lib/copy_tuner_client/cache.rb', line 78 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 |