Class: SgtnClient::Core::Cache

Inherits:
Object
  • Object
show all
Defined in:
lib/sgtn-client/core/cache.rb

Defined Under Namespace

Classes: Entry

Class Method Summary collapse

Class Method Details

.clearObject



65
66
67
68
69
70
71
72
73
# File 'lib/sgtn-client/core/cache.rb', line 65

def self.clear
    @mutex.synchronize do
        if @@data == nil
            return nil
        end
        SgtnClient.logger.debug "[Cache][clear]clear cache!"
        @@data = Hash.new
    end
end

.delete(key) ⇒ Object



55
56
57
58
59
60
61
62
63
# File 'lib/sgtn-client/core/cache.rb', line 55

def self.delete(key)
    @mutex.synchronize do
        if @@data == nil
            return nil
        end
        SgtnClient.logger.debug "[Cache][delete]delete cache for key: " + key
        @@data.delete key
    end
end

.get(key) ⇒ Object



27
28
29
30
31
32
33
# File 'lib/sgtn-client/core/cache.rb', line 27

def self.get(key)
    if @@data == nil
        return nil, nil
    end
    SgtnClient.logger.debug "[Cache][get]get cache for key: " + key
    invalidate(key)
end

.has(key) ⇒ Object



35
36
37
38
39
40
41
# File 'lib/sgtn-client/core/cache.rb', line 35

def self.has(key)
    if @@data == nil
        return nil
    end
    SgtnClient.logger.debug "[Cache][has]check if the cache has key: #{(@@data.has_key? key)}"
    @@data.has_key? key
end

.initialize(disabled = false, opts = {}) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
# File 'lib/sgtn-client/core/cache.rb', line 7

def self.initialize(disabled=false, opts={})
    @@opts = opts
    @mutex = Mutex.new
    if disabled == false
        @@data = Hash.new
        SgtnClient.logger.debug "[Cache][initialize]cache is enabled!"
    else
        @@data = nil
        SgtnClient.logger.debug "[Cache][initialize]cache is disabled!"
    end
end

.invalidate(key) ⇒ Object



75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'lib/sgtn-client/core/cache.rb', line 75

def self.invalidate(key)
    @mutex.synchronize do
        if @@data == nil
            return nil, nil
        end
        SgtnClient.logger.debug "[Cache][invalidate]invalidate expired cache......"
        now = Time.now
        if has(key)
            v = @@data[key]
            expired = false
            SgtnClient.logger.debug "[Cache][invalidate]check cache: key=#{key}, expiredtime=#{v[:expiry]}, now=#{now}, expired=#{(v[:expiry] < now)}"
            if v[:expiry] < now
                SgtnClient.logger.debug "[Cache][invalidate]before deleting the cache: data=#{@@data}"
                @@data.delete(key)
                SgtnClient.logger.debug "[Cache][invalidate]after deleting the cache: data=#{@@data}"
                expired = true
            end
            return expired, v[:value]
        else
            return nil, nil
        end
    end
end

.keysObject



19
20
21
22
23
24
25
# File 'lib/sgtn-client/core/cache.rb', line 19

def self.keys
    if @@data == nil
        return nil
    end
    SgtnClient.logger.debug "[Cache][keys]get cache keys"
    @@data.keys
end

.put(key, value, ttl = nil) ⇒ Object



43
44
45
46
47
48
49
50
51
52
53
# File 'lib/sgtn-client/core/cache.rb', line 43

def self.put(key, value, ttl=nil)
    @mutex.synchronize do
        if @@data == nil || value == nil
            return nil
        end
        ttl ||= @@opts[:ttl]
        # hours from new
        SgtnClient.logger.debug "[Cache][put]put cache for key '" + key + "' with expired time at'" + (Time.now + ttl*60).to_s
        @@data[key] = Entry.new(Time.now + ttl*60, value)
    end
end