radiospiel-app 0.2.7 → 0.2.9

Sign up to get free protection for your applications and to get access to all the features.
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.2.7
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
- if !(cache_url = App.config[:cache])
35
- App.logger.warn "No :cache configuration"
36
- elsif !(self.store = connect_to_redis(cache_url))
37
- App.logger.warn "Using cache at #{cache_url}"
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 "Cannot load 'redis' gem (connecting to #{url})"
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
- r = yield(benchmarker)
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.msg}: #{(runtime * 1000).to_i} msecs"
28
+ warn "FAIL #{benchmarker}"
29
29
  raise
30
30
  end
31
31
  end
@@ -5,7 +5,7 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = "radiospiel-app"
8
- s.version = "0.2.7"
8
+ s.version = "0.2.9"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["radiospiel"]
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.7
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: &70330854434080 !ruby/object:Gem::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: *70330854434080
24
+ version_requirements: *70297298449160
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: sqlite3
27
- requirement: &70330854433320 !ruby/object:Gem::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: *70330854433320
35
+ version_requirements: *70297298432140
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: redis
38
- requirement: &70330854432080 !ruby/object:Gem::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: *70330854432080
46
+ version_requirements: *70297298429600
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: micro_sql
49
- requirement: &70330854431120 !ruby/object:Gem::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: *70330854431120
57
+ version_requirements: *70297298425520
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: htmlentities
60
- requirement: &70330854430080 !ruby/object:Gem::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: *70330854430080
68
+ version_requirements: *70297298423440
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: bundler
71
- requirement: &70330854428680 !ruby/object:Gem::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: *70330854428680
79
+ version_requirements: *70297298421280
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: jeweler
82
- requirement: &70330854428100 !ruby/object:Gem::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: *70330854428100
90
+ version_requirements: *70297298420520
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: vcr
93
- requirement: &70330854426680 !ruby/object:Gem::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: *70330854426680
101
+ version_requirements: *70297298419780
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: webmock
104
- requirement: &70330854425720 !ruby/object:Gem::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: *70330854425720
112
+ version_requirements: *70297298418960
113
113
  - !ruby/object:Gem::Dependency
114
114
  name: psych
115
- requirement: &70330854424600 !ruby/object:Gem::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: *70330854424600
123
+ version_requirements: *70297298418020
124
124
  - !ruby/object:Gem::Dependency
125
125
  name: simplecov
126
- requirement: &70330854423240 !ruby/object:Gem::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: *70330854423240
134
+ version_requirements: *70297298417140
135
135
  - !ruby/object:Gem::Dependency
136
136
  name: ruby-debug19
137
- requirement: &70330854422400 !ruby/object:Gem::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: *70330854422400
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: 4363741734785614035
218
+ hash: 4380036455675446384
219
219
  required_rubygems_version: !ruby/object:Gem::Requirement
220
220
  none: false
221
221
  requirements: