json_schematize 0.6.2 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile +1 -1
- data/Gemfile.lock +10 -3
- data/docker-compose.yml +1 -8
- data/lib/json_schematize/cache/class_methods/client.rb +71 -0
- data/lib/json_schematize/cache/class_methods/configuration.rb +44 -0
- data/lib/json_schematize/cache/instance_methods.rb +8 -5
- data/lib/json_schematize/cache.rb +6 -4
- data/lib/json_schematize/configuration.rb +85 -0
- data/lib/json_schematize/version.rb +1 -1
- data/lib/json_schematize.rb +21 -1
- metadata +6 -4
- data/lib/json_schematize/cache/class_methods.rb +0 -81
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 332c8451a65d8d3ef3c738e6a06d54407e62d479f6d0f015aa348c01c8c70f03
|
4
|
+
data.tar.gz: 534ae0f9dd57ee349c99fa75305370241470afb99ca0273afe98d9b206a9eb57
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ce9ed85a4db89c977231290127487fde0d703ac527009173d28d0d10a1ced80a43d1febcb8cc3e4dff3b64bd80dc20c2817dd14fe301c478d3169342799f1187
|
7
|
+
data.tar.gz: 6eca9b7c49801e97d1393157c8c49a42ffafcb26bcdc103974329c2222ce3f804a496038f1cf8041836170ac251b3e9f977727f99d4bd11edad6de47931b76de
|
data/Gemfile
CHANGED
data/Gemfile.lock
CHANGED
@@ -1,11 +1,16 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
json_schematize (0.
|
4
|
+
json_schematize (0.7.0)
|
5
5
|
|
6
6
|
GEM
|
7
7
|
remote: https://rubygems.org/
|
8
8
|
specs:
|
9
|
+
activesupport (7.0.2.4)
|
10
|
+
concurrent-ruby (~> 1.0, >= 1.0.2)
|
11
|
+
i18n (>= 1.6, < 2)
|
12
|
+
minitest (>= 5.1)
|
13
|
+
tzinfo (~> 2.0)
|
9
14
|
byebug (11.1.3)
|
10
15
|
coderay (1.1.3)
|
11
16
|
concurrent-ruby (1.1.9)
|
@@ -16,6 +21,7 @@ GEM
|
|
16
21
|
i18n (1.10.0)
|
17
22
|
concurrent-ruby (~> 1.0)
|
18
23
|
method_source (1.0.0)
|
24
|
+
minitest (5.15.0)
|
19
25
|
pry (0.13.1)
|
20
26
|
coderay (~> 1.1)
|
21
27
|
method_source (~> 1.0)
|
@@ -23,7 +29,6 @@ GEM
|
|
23
29
|
byebug (~> 11.0)
|
24
30
|
pry (~> 0.13.0)
|
25
31
|
rake (12.3.3)
|
26
|
-
redis (4.6.0)
|
27
32
|
rspec (3.11.0)
|
28
33
|
rspec-core (~> 3.11.0)
|
29
34
|
rspec-expectations (~> 3.11.0)
|
@@ -45,17 +50,19 @@ GEM
|
|
45
50
|
simplecov_json_formatter (~> 0.1)
|
46
51
|
simplecov-html (0.12.3)
|
47
52
|
simplecov_json_formatter (0.1.4)
|
53
|
+
tzinfo (2.0.4)
|
54
|
+
concurrent-ruby (~> 1.0)
|
48
55
|
|
49
56
|
PLATFORMS
|
50
57
|
x86_64-linux
|
51
58
|
|
52
59
|
DEPENDENCIES
|
60
|
+
activesupport
|
53
61
|
faker
|
54
62
|
json_schematize!
|
55
63
|
pry
|
56
64
|
pry-byebug
|
57
65
|
rake (~> 12.0)
|
58
|
-
redis
|
59
66
|
rspec (~> 3.0)
|
60
67
|
rspec_junit_formatter
|
61
68
|
simplecov
|
data/docker-compose.yml
CHANGED
@@ -0,0 +1,71 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module JsonSchematize::Cache::ClassMethods
|
4
|
+
module Client
|
5
|
+
|
6
|
+
def __deserialize_keys__(key_hash_bytes)
|
7
|
+
return [{}, 0] if key_hash_bytes.nil?
|
8
|
+
|
9
|
+
min_expire = Time.now.to_i
|
10
|
+
key_hash = Marshal.load(key_hash_bytes)
|
11
|
+
keys_removed = 0
|
12
|
+
key_hash.each do |key, expire|
|
13
|
+
next if expire.to_i > min_expire
|
14
|
+
|
15
|
+
key_hash.delete(key)
|
16
|
+
keys_removed += 1
|
17
|
+
end
|
18
|
+
|
19
|
+
[key_hash, keys_removed]
|
20
|
+
rescue StandardError => e
|
21
|
+
::Kernel.warn("Yikes!! Failed to parse. Returning empty. #{e.message}")
|
22
|
+
[{}, 0]
|
23
|
+
end
|
24
|
+
|
25
|
+
def __update_record_keeper__!(expire:, cache_key:, delete_key: false)
|
26
|
+
record_of_truth = cached_keys(with_expire: true)
|
27
|
+
if delete_key
|
28
|
+
record_of_truth.delete(cache_key)
|
29
|
+
else
|
30
|
+
record_of_truth[cache_key] = expire
|
31
|
+
end
|
32
|
+
serialized_string = Marshal.dump(record_of_truth)
|
33
|
+
|
34
|
+
cache_client.write(cache_namespace, serialized_string)
|
35
|
+
end
|
36
|
+
|
37
|
+
def __delete_record__!(key)
|
38
|
+
__update_record_keeper__!(expire: nil, cache_key: key, delete_key: true)
|
39
|
+
end
|
40
|
+
|
41
|
+
def cached_keys(with_expire: false, count_removed: false)
|
42
|
+
raw_string = cache_client.read(cache_namespace)
|
43
|
+
key_hash, keys_removed = __deserialize_keys__(raw_string)
|
44
|
+
return key_hash if with_expire
|
45
|
+
return keys_removed if count_removed
|
46
|
+
|
47
|
+
key_hash.keys
|
48
|
+
end
|
49
|
+
|
50
|
+
def cached_items(key_includes: nil)
|
51
|
+
clear_unscored_items! if rand > cache_configuration[:stochastic_cache_bust]
|
52
|
+
|
53
|
+
cached_keys.map do |key|
|
54
|
+
if key_includes
|
55
|
+
next unless key.include?(key_includes)
|
56
|
+
end
|
57
|
+
|
58
|
+
serialized_string = cache_client.read(key)
|
59
|
+
Marshal.load(serialized_string)
|
60
|
+
end.compact
|
61
|
+
end
|
62
|
+
|
63
|
+
def clear_cache!
|
64
|
+
cache_client.delete_multi(([cache_namespace] + cached_keys))
|
65
|
+
end
|
66
|
+
|
67
|
+
def clear_unscored_items!
|
68
|
+
cached_keys(count_removed: true)
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module JsonSchematize::Cache::ClassMethods
|
4
|
+
module Configuration
|
5
|
+
def cache_options(key: nil, cache_client: nil, cache_namespace: nil, ttl: nil, update_on_change: nil, stochastic_cache_bust: nil)
|
6
|
+
cache_configuration[:key] = key if key
|
7
|
+
cache_configuration[:ttl] = ttl if ttl
|
8
|
+
cache_configuration[:stochastic_cache_bust] = stochastic_cache_bust if stochastic_cache_bust
|
9
|
+
cache_configuration[:update_on_change] = update_on_change if update_on_change
|
10
|
+
cache_namespace = cache_configuration[:cache_namespace] = cache_namespace if cache_namespace
|
11
|
+
|
12
|
+
self.cache_client = cache_configuration[:cache_client] = cache_client if cache_client
|
13
|
+
end
|
14
|
+
|
15
|
+
def cache_namespace
|
16
|
+
cache_configuration[:cache_namespace] ||= "jss:#{self.name.downcase}"
|
17
|
+
end
|
18
|
+
|
19
|
+
def cache_namespace=(namespace)
|
20
|
+
cache_configuration[:cache_namespace] = namespace
|
21
|
+
end
|
22
|
+
|
23
|
+
def cache_configuration
|
24
|
+
@cache_configuration ||= begin
|
25
|
+
{
|
26
|
+
cache_client: JsonSchematize.configuration.cache_client,
|
27
|
+
cache_namespace: JsonSchematize.configuration.cache_namespace,
|
28
|
+
key: JsonSchematize.configuration.cache_key,
|
29
|
+
stochastic_cache_bust: JsonSchematize.configuration.cache_stochastic_bust,
|
30
|
+
ttl: JsonSchematize.configuration.cache_ttl,
|
31
|
+
update_on_change: JsonSchematize.configuration.cache_update_on_change,
|
32
|
+
}
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def cache_client=(client)
|
37
|
+
cache_configuration[:cache_client] = client
|
38
|
+
end
|
39
|
+
|
40
|
+
def cache_client
|
41
|
+
cache_configuration[:cache_client].is_a?(Proc) ? cache_configuration[:cache_client].call : cache_configuration[:cache_client]
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module JsonSchematize
|
2
4
|
module Cache
|
3
5
|
module InstanceMethods
|
@@ -12,16 +14,17 @@ module JsonSchematize
|
|
12
14
|
|
13
15
|
def __update_cache_item__(with_delete: true)
|
14
16
|
__clear_entry__! if with_delete # needs to get done first in the event the cache_key changes
|
15
|
-
client = self.class.
|
17
|
+
client = self.class.cache_client
|
16
18
|
ttl = self.class.cache_configuration[:ttl].to_i
|
17
19
|
score = Time.now.to_i + ttl
|
18
|
-
|
19
|
-
|
20
|
+
self.class.__update_record_keeper__!(expire: score, cache_key: __cache_key__)
|
21
|
+
|
22
|
+
client.write(__cache_key__, Marshal.dump(self), expires_in: ttl)
|
20
23
|
end
|
21
24
|
|
22
25
|
def __clear_entry__!
|
23
|
-
self.class.
|
24
|
-
self.class.
|
26
|
+
self.class.cache_client.delete(__cache_key__)
|
27
|
+
self.class.__delete_record__!(__cache_key__)
|
25
28
|
end
|
26
29
|
|
27
30
|
def __cache_key__
|
@@ -1,15 +1,17 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require "json_schematize/cache/instance_methods"
|
4
|
-
require "json_schematize/cache/class_methods"
|
4
|
+
require "json_schematize/cache/class_methods/client"
|
5
|
+
require "json_schematize/cache/class_methods/configuration"
|
5
6
|
|
6
7
|
module JsonSchematize
|
7
8
|
module Cache
|
8
|
-
|
9
|
-
raise StandardError, "Yikes! JsonSchematize::Cache Needs Redis to work. Include it as a gem" unless defined?(Redis)
|
9
|
+
module ClassMethods; end
|
10
10
|
|
11
|
+
def self.included(base)
|
11
12
|
base.include(JsonSchematize::Cache::InstanceMethods)
|
12
|
-
base.extend(JsonSchematize::Cache::ClassMethods)
|
13
|
+
base.extend(JsonSchematize::Cache::ClassMethods::Client)
|
14
|
+
base.extend(JsonSchematize::Cache::ClassMethods::Configuration)
|
13
15
|
end
|
14
16
|
end
|
15
17
|
end
|
@@ -0,0 +1,85 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module JsonSchematize
|
4
|
+
class Configuration
|
5
|
+
DEFAULT_ONE_MIN = 60 * 60
|
6
|
+
DEFAULT_ONE_HOUR = DEFAULT_ONE_MIN * 60
|
7
|
+
DEFAULT_ONE_DAY = DEFAULT_ONE_HOUR * 24
|
8
|
+
DEFAULT_CACHE_OPTIONS = {
|
9
|
+
cache_client: nil,
|
10
|
+
cache_key: ->(val, _custom_key) { val.hash },
|
11
|
+
cache_namespace: nil,
|
12
|
+
cache_stochastic_bust: 0.8,
|
13
|
+
cache_ttl: DEFAULT_ONE_DAY,
|
14
|
+
cache_update_on_change: true,
|
15
|
+
}
|
16
|
+
|
17
|
+
attr_accessor *DEFAULT_CACHE_OPTIONS.keys
|
18
|
+
|
19
|
+
def initialize
|
20
|
+
@cache_client = DEFAULT_CACHE_OPTIONS[:cache_client]
|
21
|
+
@cache_key = DEFAULT_CACHE_OPTIONS[:cache_key]
|
22
|
+
@cache_namespace = DEFAULT_CACHE_OPTIONS[:cache_namespace]
|
23
|
+
@cache_stochastic_bust = DEFAULT_CACHE_OPTIONS[:cache_stochastic_bust]
|
24
|
+
@cache_ttl = DEFAULT_CACHE_OPTIONS[:cache_ttl]
|
25
|
+
@cache_update_on_change = DEFAULT_CACHE_OPTIONS[:cache_update_on_change]
|
26
|
+
end
|
27
|
+
|
28
|
+
def cache_hash
|
29
|
+
DEFAULT_CACHE_OPTIONS.map do |key, value|
|
30
|
+
val = public_send(key)
|
31
|
+
[key, val]
|
32
|
+
end.to_h
|
33
|
+
end
|
34
|
+
|
35
|
+
def cache_key=(value)
|
36
|
+
if value.is_a? Proc
|
37
|
+
@key = value
|
38
|
+
return @key
|
39
|
+
end
|
40
|
+
|
41
|
+
assign = _assign_msg_("cache_key", "->(val, cusom_key) { val.hash }", "Default proc to assign cache key")
|
42
|
+
msg = "cache_key must be a proc. \n#{assign}"
|
43
|
+
raise JsonSchematize::ConfigError, msg
|
44
|
+
end
|
45
|
+
|
46
|
+
def cache_client=(client)
|
47
|
+
min_required = [:read, :write, :delete_multi, :read_multi]
|
48
|
+
min_required.each do |meth|
|
49
|
+
next if client.methods.include?(meth)
|
50
|
+
|
51
|
+
assign = _assign_msg_("cache_client", "_initialized_client_", "Preferably an ActiveSupport::Cache::Store supported client")
|
52
|
+
msg = "Passed in client does not accept minimum values. #{min_required} are required methods \n#{assign}"
|
53
|
+
raise JsonSchematize::ConfigError, msg
|
54
|
+
end
|
55
|
+
|
56
|
+
|
57
|
+
@cache_client = client
|
58
|
+
end
|
59
|
+
|
60
|
+
def cache_client
|
61
|
+
return @cache_client unless @cache_client.nil?
|
62
|
+
|
63
|
+
begin
|
64
|
+
Kernel.require 'active_support'
|
65
|
+
rescue LoadError
|
66
|
+
assign = _assign_msg_("cache_client", "ActiveSupport::Cache::MemoryStore.new", "A ActiveSupport::Cache::Store supported client")
|
67
|
+
msg = "Default client missing. Attempted to use 'active_support/cache' but not loaded. \n#{assign}"
|
68
|
+
raise JsonSchematize::ConfigError, msg
|
69
|
+
end
|
70
|
+
|
71
|
+
@cache_client = ActiveSupport::Cache::MemoryStore.new
|
72
|
+
@cache_client
|
73
|
+
end
|
74
|
+
|
75
|
+
private
|
76
|
+
|
77
|
+
def _assign_msg_(key, assignment, comment)
|
78
|
+
config = " config.#{key} = #{assignment} # #{comment}"
|
79
|
+
"\n\n# Initializer for json_schematize\n" \
|
80
|
+
"JsonSchematize.configure do |config|\n" \
|
81
|
+
"#{config}\n" \
|
82
|
+
"end\n\n"
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
data/lib/json_schematize.rb
CHANGED
@@ -4,12 +4,14 @@ require "json_schematize/version"
|
|
4
4
|
|
5
5
|
require "json_schematize/base"
|
6
6
|
require "json_schematize/boolean"
|
7
|
-
require "json_schematize/
|
7
|
+
require "json_schematize/configuration"
|
8
8
|
require "json_schematize/empty_value"
|
9
|
+
require "json_schematize/generator"
|
9
10
|
require "json_schematize/version"
|
10
11
|
|
11
12
|
module JsonSchematize
|
12
13
|
class Error < StandardError; end
|
14
|
+
class ConfigError < StandardError; end
|
13
15
|
class FieldError < Error; end
|
14
16
|
class InvalidField < Error; end
|
15
17
|
class InvalidFieldByValidator < InvalidField; end
|
@@ -18,4 +20,22 @@ module JsonSchematize
|
|
18
20
|
|
19
21
|
## Customized class errors
|
20
22
|
class UndefinedBoolean < Error; end
|
23
|
+
|
24
|
+
def self.configure
|
25
|
+
yield configuration if block_given?
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.configuration
|
29
|
+
@configuration ||= JsonSchematize::Configuration.new
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.configuration=(object)
|
33
|
+
raise ConfigError, "Expected configuration to be a JsonSchematize::Configuration" unless object.is_a?(JsonSchematize::Configuration)
|
34
|
+
|
35
|
+
@configuration = object
|
36
|
+
end
|
37
|
+
|
38
|
+
def self.cache_client
|
39
|
+
configuration.cache_client
|
40
|
+
end
|
21
41
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: json_schematize
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.7.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Matt Taylor
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-
|
11
|
+
date: 2022-05-07 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: pry-byebug
|
@@ -92,8 +92,10 @@ files:
|
|
92
92
|
- lib/json_schematize/base.rb
|
93
93
|
- lib/json_schematize/boolean.rb
|
94
94
|
- lib/json_schematize/cache.rb
|
95
|
-
- lib/json_schematize/cache/class_methods.rb
|
95
|
+
- lib/json_schematize/cache/class_methods/client.rb
|
96
|
+
- lib/json_schematize/cache/class_methods/configuration.rb
|
96
97
|
- lib/json_schematize/cache/instance_methods.rb
|
98
|
+
- lib/json_schematize/configuration.rb
|
97
99
|
- lib/json_schematize/empty_value.rb
|
98
100
|
- lib/json_schematize/field.rb
|
99
101
|
- lib/json_schematize/field_transformations.rb
|
@@ -122,7 +124,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
122
124
|
- !ruby/object:Gem::Version
|
123
125
|
version: '0'
|
124
126
|
requirements: []
|
125
|
-
rubygems_version: 3.
|
127
|
+
rubygems_version: 3.3.11
|
126
128
|
signing_key:
|
127
129
|
specification_version: 4
|
128
130
|
summary: This gem gives you the ability to turn API results into a standardized schema's
|
@@ -1,81 +0,0 @@
|
|
1
|
-
module JsonSchematize
|
2
|
-
module Cache
|
3
|
-
module ClassMethods
|
4
|
-
DEFAULT_ONE_MIN = 60 * 60
|
5
|
-
DEFAULT_ONE_HOUR = DEFAULT_ONE_MIN * 60
|
6
|
-
DEFAULT_ONE_DAY = DEFAULT_ONE_HOUR * 24
|
7
|
-
DEFAULT_URL = ENV["CACHE_LAYER_REDIS_URL"] || ENV["REDIS_URL"]
|
8
|
-
DEFAULTS = {
|
9
|
-
redis_url: DEFAULT_URL,
|
10
|
-
ttl: DEFAULT_ONE_DAY,
|
11
|
-
key: ->(val, _custom_key) { val.hash },
|
12
|
-
update_on_change: true,
|
13
|
-
redis_client: ->() { ::Redis.new(url: DEFAULT_URL) },
|
14
|
-
stochastic_cache_bust: 0.8,
|
15
|
-
}
|
16
|
-
|
17
|
-
def cache_options(key: nil, redis_url: nil, redis_client: nil, cache_namespace: nil, ttl: nil, update_on_change: nil, stochastic_cache_bust: nil)
|
18
|
-
cache_configuration[:key] = key if key
|
19
|
-
cache_configuration[:ttl] = ttl if ttl
|
20
|
-
cache_configuration[:stochastic_cache_bust] = stochastic_cache_bust if stochastic_cache_bust
|
21
|
-
cache_configuration[:update_on_change] = update_on_change if update_on_change
|
22
|
-
cache_namespace = cache_configuration[:cache_namespace] = cache_namespace if cache_namespace
|
23
|
-
|
24
|
-
self.redis_client = cache_configuration[:redis_client] = redis_client if redis_client
|
25
|
-
self.redis_url = cache_configuration[:redis_url] = redis_url if redis_url
|
26
|
-
end
|
27
|
-
|
28
|
-
def cache_namespace
|
29
|
-
cache_configuration[:cache_namespace] ||= "jss:#{self.name.downcase}"
|
30
|
-
end
|
31
|
-
|
32
|
-
def cache_namespace=(namespace)
|
33
|
-
cache_configuration[:cache_namespace] = namespace
|
34
|
-
end
|
35
|
-
|
36
|
-
def cache_configuration
|
37
|
-
@cache_configuration ||= DEFAULTS.clone
|
38
|
-
end
|
39
|
-
|
40
|
-
def redis_client=(client)
|
41
|
-
cache_configuration[:redis_client] = client
|
42
|
-
end
|
43
|
-
|
44
|
-
def redis_url=(url)
|
45
|
-
cache_configuration[:redis_url] = url
|
46
|
-
cache_configuration[:redis_client] = ::Redis.new(url: url)
|
47
|
-
end
|
48
|
-
|
49
|
-
def redis_client
|
50
|
-
cache_configuration[:redis_client].is_a?(Proc) ? cache_configuration[:redis_client].call : cache_configuration[:redis_client]
|
51
|
-
end
|
52
|
-
|
53
|
-
def cached_keys
|
54
|
-
max_length = Time.now.to_i + cache_configuration[:ttl].to_i + 10
|
55
|
-
redis_client.zrangebyscore(cache_namespace, Time.now.to_i, "+inf")
|
56
|
-
end
|
57
|
-
|
58
|
-
def cached_items(key_includes: nil)
|
59
|
-
clear_unscored_items! if rand > cache_configuration[:stochastic_cache_bust]
|
60
|
-
|
61
|
-
cached_keys.map do |key|
|
62
|
-
if key_includes
|
63
|
-
next unless key.include?(key_includes)
|
64
|
-
end
|
65
|
-
|
66
|
-
serialized_string = redis_client.get(key)
|
67
|
-
Marshal.load(serialized_string)
|
68
|
-
end.compact
|
69
|
-
end
|
70
|
-
|
71
|
-
def clear_cache!
|
72
|
-
redis_client.unlink(*cached_keys) if cached_keys.length > 0
|
73
|
-
redis_client.unlink(cache_namespace)
|
74
|
-
end
|
75
|
-
|
76
|
-
def clear_unscored_items!
|
77
|
-
redis_client.zremrangebyscore(cache_namespace, "-inf", Time.now.to_i)
|
78
|
-
end
|
79
|
-
end
|
80
|
-
end
|
81
|
-
end
|