radiospiel-app 0.2.7 → 0.2.9
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.
- data/VERSION +1 -1
- data/lib/app/app/cache.rb +47 -10
- data/lib/core-extensions/benchmark-logger.rb +7 -7
- data/radiospiel-app.gemspec +1 -1
- metadata +26 -26
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.2.
|
1
|
+
0.2.9
|
data/lib/app/app/cache.rb
CHANGED
@@ -7,6 +7,39 @@ require_relative "config"
|
|
7
7
|
# Entries are packed via Marshal.
|
8
8
|
module App
|
9
9
|
module Cache
|
10
|
+
class SqliteStore < MicroSql::KeyValueTable
|
11
|
+
def self.db_path
|
12
|
+
@db_path ||= begin
|
13
|
+
path = "#{Dir.home}/cache/#{File.basename(App.root)}/#{App.root.uid64}.sqlite3"
|
14
|
+
FileUtils.mkdir_p File.dirname(path)
|
15
|
+
path
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
def initialize
|
20
|
+
@db = MicroSql.create(SqliteStore.db_path)
|
21
|
+
super @db, "cache"
|
22
|
+
end
|
23
|
+
|
24
|
+
def get(key)
|
25
|
+
encoded = self[key]
|
26
|
+
Base64.decode64(encoded) if encoded
|
27
|
+
end
|
28
|
+
|
29
|
+
def set(key, value)
|
30
|
+
update key, Base64.encode64(value)
|
31
|
+
end
|
32
|
+
|
33
|
+
def expire(key, max_age)
|
34
|
+
ttl = max_age + Time.now.to_i if max_age
|
35
|
+
@db.ask("UPDATE cache SET ttl=? WHERE uid=?", ttl, key)
|
36
|
+
end
|
37
|
+
|
38
|
+
def flushdb
|
39
|
+
@db.exec "DELETE FROM cache"
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
10
43
|
DEFAULT_MAX_AGE = 4 * 3600 # 4 hours.
|
11
44
|
|
12
45
|
attr :store, true
|
@@ -31,18 +64,22 @@ module App
|
|
31
64
|
end
|
32
65
|
|
33
66
|
def self.setup
|
34
|
-
|
35
|
-
App.logger.warn "No :cache configuration"
|
36
|
-
|
37
|
-
|
67
|
+
cache_url = App.config[:cache] || begin
|
68
|
+
App.logger.warn "No :cache configuration, fallback to #{SqliteStore.db_path}"
|
69
|
+
SqliteStore.db_path
|
70
|
+
end
|
71
|
+
|
72
|
+
uri = URI.parse(cache_url)
|
73
|
+
|
74
|
+
self.store = case uri.scheme
|
75
|
+
when "redis"
|
76
|
+
require "redis"
|
77
|
+
Redis.connect(:url => cache_url)
|
78
|
+
when nil
|
79
|
+
SqliteStore.new
|
38
80
|
end
|
39
|
-
end
|
40
|
-
|
41
|
-
def self.connect_to_redis(url)
|
42
|
-
require "redis"
|
43
|
-
Redis.connect(:url => url)
|
44
81
|
rescue LoadError
|
45
|
-
App.logger.warn "
|
82
|
+
App.logger.warn "LoadError: #{$!}"
|
46
83
|
nil
|
47
84
|
end
|
48
85
|
end
|
@@ -13,19 +13,19 @@ class Logger
|
|
13
13
|
def runtime
|
14
14
|
Time.now - @start
|
15
15
|
end
|
16
|
+
|
17
|
+
def to_s
|
18
|
+
"#{msg}: #{(runtime * 1000).to_i} msecs"
|
19
|
+
end
|
16
20
|
end
|
17
21
|
|
18
22
|
def benchmark(msg = "Benchmark", opts = {}, &block)
|
19
23
|
benchmarker = Benchmarker.new(msg, opts[:severity] || :warn)
|
20
|
-
|
21
|
-
|
22
|
-
runtime = benchmarker.runtime
|
23
|
-
if runtime > (opts[:minimum] || -1)
|
24
|
-
self.send benchmarker.severity, "#{benchmarker.msg}: #{(runtime * 1000).to_i} msecs"
|
24
|
+
yield(benchmarker).tap do
|
25
|
+
self.send(benchmarker.severity, benchmarker.to_s) if benchmarker.runtime > (opts[:minimum] || -1)
|
25
26
|
end
|
26
|
-
r
|
27
27
|
rescue
|
28
|
-
warn "FAIL #{benchmarker
|
28
|
+
warn "FAIL #{benchmarker}"
|
29
29
|
raise
|
30
30
|
end
|
31
31
|
end
|
data/radiospiel-app.gemspec
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: radiospiel-app
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.9
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -13,7 +13,7 @@ date: 2012-04-04 00:00:00.000000000 Z
|
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: pg
|
16
|
-
requirement: &
|
16
|
+
requirement: &70297298449160 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ! '>='
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0'
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *70297298449160
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: sqlite3
|
27
|
-
requirement: &
|
27
|
+
requirement: &70297298432140 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ! '>='
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '0'
|
33
33
|
type: :runtime
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *70297298432140
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: redis
|
38
|
-
requirement: &
|
38
|
+
requirement: &70297298429600 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ! '>='
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: '0'
|
44
44
|
type: :runtime
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *70297298429600
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: micro_sql
|
49
|
-
requirement: &
|
49
|
+
requirement: &70297298425520 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ! '>='
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: '0'
|
55
55
|
type: :runtime
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *70297298425520
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: htmlentities
|
60
|
-
requirement: &
|
60
|
+
requirement: &70297298423440 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ! '>='
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: '0'
|
66
66
|
type: :runtime
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *70297298423440
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: bundler
|
71
|
-
requirement: &
|
71
|
+
requirement: &70297298421280 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ! '>='
|
@@ -76,10 +76,10 @@ dependencies:
|
|
76
76
|
version: '0'
|
77
77
|
type: :development
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *70297298421280
|
80
80
|
- !ruby/object:Gem::Dependency
|
81
81
|
name: jeweler
|
82
|
-
requirement: &
|
82
|
+
requirement: &70297298420520 !ruby/object:Gem::Requirement
|
83
83
|
none: false
|
84
84
|
requirements:
|
85
85
|
- - ! '>='
|
@@ -87,10 +87,10 @@ dependencies:
|
|
87
87
|
version: '0'
|
88
88
|
type: :development
|
89
89
|
prerelease: false
|
90
|
-
version_requirements: *
|
90
|
+
version_requirements: *70297298420520
|
91
91
|
- !ruby/object:Gem::Dependency
|
92
92
|
name: vcr
|
93
|
-
requirement: &
|
93
|
+
requirement: &70297298419780 !ruby/object:Gem::Requirement
|
94
94
|
none: false
|
95
95
|
requirements:
|
96
96
|
- - ! '>='
|
@@ -98,10 +98,10 @@ dependencies:
|
|
98
98
|
version: '0'
|
99
99
|
type: :development
|
100
100
|
prerelease: false
|
101
|
-
version_requirements: *
|
101
|
+
version_requirements: *70297298419780
|
102
102
|
- !ruby/object:Gem::Dependency
|
103
103
|
name: webmock
|
104
|
-
requirement: &
|
104
|
+
requirement: &70297298418960 !ruby/object:Gem::Requirement
|
105
105
|
none: false
|
106
106
|
requirements:
|
107
107
|
- - ! '>='
|
@@ -109,10 +109,10 @@ dependencies:
|
|
109
109
|
version: '0'
|
110
110
|
type: :development
|
111
111
|
prerelease: false
|
112
|
-
version_requirements: *
|
112
|
+
version_requirements: *70297298418960
|
113
113
|
- !ruby/object:Gem::Dependency
|
114
114
|
name: psych
|
115
|
-
requirement: &
|
115
|
+
requirement: &70297298418020 !ruby/object:Gem::Requirement
|
116
116
|
none: false
|
117
117
|
requirements:
|
118
118
|
- - ! '>='
|
@@ -120,10 +120,10 @@ dependencies:
|
|
120
120
|
version: '0'
|
121
121
|
type: :development
|
122
122
|
prerelease: false
|
123
|
-
version_requirements: *
|
123
|
+
version_requirements: *70297298418020
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: simplecov
|
126
|
-
requirement: &
|
126
|
+
requirement: &70297298417140 !ruby/object:Gem::Requirement
|
127
127
|
none: false
|
128
128
|
requirements:
|
129
129
|
- - ! '>='
|
@@ -131,10 +131,10 @@ dependencies:
|
|
131
131
|
version: '0'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
|
-
version_requirements: *
|
134
|
+
version_requirements: *70297298417140
|
135
135
|
- !ruby/object:Gem::Dependency
|
136
136
|
name: ruby-debug19
|
137
|
-
requirement: &
|
137
|
+
requirement: &70297295190040 !ruby/object:Gem::Requirement
|
138
138
|
none: false
|
139
139
|
requirements:
|
140
140
|
- - ! '>='
|
@@ -142,7 +142,7 @@ dependencies:
|
|
142
142
|
version: '0'
|
143
143
|
type: :development
|
144
144
|
prerelease: false
|
145
|
-
version_requirements: *
|
145
|
+
version_requirements: *70297295190040
|
146
146
|
description: Some basics that your application could benefit from.
|
147
147
|
email: eno@open-lab.org
|
148
148
|
executables: []
|
@@ -215,7 +215,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
215
215
|
version: '0'
|
216
216
|
segments:
|
217
217
|
- 0
|
218
|
-
hash:
|
218
|
+
hash: 4380036455675446384
|
219
219
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
220
220
|
none: false
|
221
221
|
requirements:
|