uzuuzu-core 0.0.8 → 0.0.9
Sign up to get free protection for your applications and to get access to all the features.
- data/VERSION +1 -1
- data/lib/uzuuzu/{wrapper/application.rb → application.rb} +2 -1
- data/lib/uzuuzu/{wrapper/controller.rb → controller.rb} +1 -15
- data/lib/uzuuzu/controller/error.rb +11 -0
- data/lib/uzuuzu/controller/view/error/404.rhtml +6 -0
- data/lib/uzuuzu/controller/view/error/500.rhtml +6 -0
- data/lib/uzuuzu/datastore/activerecord.rb +1 -0
- data/lib/uzuuzu/datastore/datamapper.rb +116 -0
- data/lib/uzuuzu/datastore/sequel.rb +0 -0
- data/lib/uzuuzu/{wrapper/environments.rb → environments.rb} +29 -46
- data/lib/uzuuzu/{wrapper → ext}/object.rb +0 -0
- data/lib/uzuuzu/fixture/datamapper.rb +114 -0
- data/lib/uzuuzu/{wrapper/helper.rb → helper.rb} +1 -0
- data/lib/uzuuzu/helper/uzuuzu.rb +48 -0
- data/lib/uzuuzu/kvs/appengine.rb +65 -0
- data/lib/uzuuzu/kvs/hbase.rb +2 -0
- data/lib/uzuuzu/kvs/leveldb.rb +73 -0
- data/lib/uzuuzu/kvs/mongo.rb +68 -0
- data/lib/uzuuzu/{wrapper/lang → lang}/en.yaml +0 -0
- data/lib/uzuuzu/{wrapper/lang → lang}/ja.yaml +0 -0
- data/lib/uzuuzu/logger/appengine.rb +51 -0
- data/lib/uzuuzu/logger/file.rb +50 -0
- data/lib/uzuuzu/logger/loggers.rb +47 -0
- data/lib/uzuuzu/logger/stderr.rb +50 -0
- data/lib/uzuuzu/logger/stdout.rb +50 -0
- data/lib/uzuuzu/mailer/appengine.rb +27 -0
- data/lib/uzuuzu/mailer/tmail.rb +44 -0
- data/lib/uzuuzu/memcache/appengine.rb +29 -0
- data/lib/uzuuzu/memcache/dalli.rb +31 -0
- data/lib/uzuuzu/memcache/leveldb.rb +43 -0
- data/lib/uzuuzu/memcache/memcached.rb +23 -0
- data/lib/uzuuzu/rack_session/appengine.rb +40 -0
- data/lib/uzuuzu/rack_session/cookie.rb +25 -0
- data/lib/uzuuzu/rack_session/datastore.rb +22 -0
- data/lib/uzuuzu/rack_session/memcache.rb +67 -0
- data/lib/uzuuzu/{wrapper/request.rb → request.rb} +0 -0
- data/lib/uzuuzu/{wrapper/response.rb → response.rb} +0 -1
- data/lib/uzuuzu/{wrapper/tilt.rb → tilt.rb} +3 -3
- data/lib/uzuuzu/wrapper/logger.rb +23 -103
- data/lib/uzuuzu/wrapper/uzuuzu.rb +22 -42
- data/lib/uzuuzu/wrapper/wrapper.rb +31 -0
- data/lib/uzuuzu_core.rb +19 -0
- data/uzuuzu-core.gemspec +41 -17
- metadata +42 -18
- data/lib/uzuuzu-core.rb +0 -9
- data/lib/uzuuzu/uzuuzu-core.rb +0 -17
- data/lib/uzuuzu/wrapper/datastore.rb +0 -55
- data/lib/uzuuzu/wrapper/mailer.rb +0 -20
- data/lib/uzuuzu/wrapper/memcache.rb +0 -20
@@ -0,0 +1,48 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
|
3
|
+
module UzuUzu
|
4
|
+
#
|
5
|
+
#
|
6
|
+
#
|
7
|
+
module Helper
|
8
|
+
#
|
9
|
+
#
|
10
|
+
#
|
11
|
+
module UzuUzuHelper
|
12
|
+
#
|
13
|
+
#
|
14
|
+
#
|
15
|
+
def logger
|
16
|
+
::UzuUzu.logger
|
17
|
+
end
|
18
|
+
|
19
|
+
#
|
20
|
+
#
|
21
|
+
#
|
22
|
+
def memcache
|
23
|
+
::UzuUzu.memcache
|
24
|
+
end
|
25
|
+
|
26
|
+
#
|
27
|
+
#
|
28
|
+
#
|
29
|
+
def kvs
|
30
|
+
::UzuUzu.kvs
|
31
|
+
end
|
32
|
+
|
33
|
+
#
|
34
|
+
#
|
35
|
+
#
|
36
|
+
def datastore
|
37
|
+
::UzuUzu.datastore
|
38
|
+
end
|
39
|
+
|
40
|
+
#
|
41
|
+
#
|
42
|
+
#
|
43
|
+
def mailer
|
44
|
+
::UzuUzu.mailer
|
45
|
+
end
|
46
|
+
end # UzuUzuHelper
|
47
|
+
end # Helper
|
48
|
+
end # UzuUzu
|
@@ -0,0 +1,65 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
# TODO
|
3
|
+
require 'appengine-apis'
|
4
|
+
require 'appengine-apis/datastore'
|
5
|
+
|
6
|
+
module UzuUzu
|
7
|
+
module Kvs
|
8
|
+
#
|
9
|
+
#
|
10
|
+
#
|
11
|
+
class Appengine
|
12
|
+
#
|
13
|
+
attr_reader :adapter
|
14
|
+
|
15
|
+
#
|
16
|
+
#
|
17
|
+
#
|
18
|
+
def initialize(env=nil)
|
19
|
+
@adapter = :appengine
|
20
|
+
@db = ::AppEngine::Detastore
|
21
|
+
end
|
22
|
+
|
23
|
+
#
|
24
|
+
#
|
25
|
+
#
|
26
|
+
def space(name)
|
27
|
+
@spaces[name] ||= Space.new(@db, name)
|
28
|
+
end
|
29
|
+
|
30
|
+
#
|
31
|
+
#
|
32
|
+
#
|
33
|
+
class Space
|
34
|
+
def initalize(db, space)
|
35
|
+
@db = db
|
36
|
+
@space = space
|
37
|
+
@resource = @db
|
38
|
+
end
|
39
|
+
|
40
|
+
def get(id)
|
41
|
+
query = Datastore::Query.new(space)
|
42
|
+
query.iterator.first
|
43
|
+
end
|
44
|
+
alias :[] :get
|
45
|
+
|
46
|
+
def put(id, entity)
|
47
|
+
|
48
|
+
end
|
49
|
+
alias :[]= :put
|
50
|
+
|
51
|
+
|
52
|
+
def method_missing(action, *args)
|
53
|
+
@resource.send(action, *args)
|
54
|
+
end # method_missing
|
55
|
+
end # Space
|
56
|
+
|
57
|
+
#
|
58
|
+
#
|
59
|
+
#
|
60
|
+
class Query
|
61
|
+
|
62
|
+
end
|
63
|
+
end # Appengine
|
64
|
+
end # Kvs
|
65
|
+
end # UzuUzu
|
@@ -0,0 +1,73 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
# TODO
|
3
|
+
require 'leveldb'
|
4
|
+
|
5
|
+
module UzuUzu
|
6
|
+
module Kvs
|
7
|
+
class Leveldb
|
8
|
+
#
|
9
|
+
attr_reader :adapter
|
10
|
+
|
11
|
+
#
|
12
|
+
#
|
13
|
+
#
|
14
|
+
def initialize(env=nil)
|
15
|
+
@adapter = :leveldb
|
16
|
+
@db = 'db'
|
17
|
+
@spaces = {}
|
18
|
+
unless env && env['address']
|
19
|
+
@db = env['address']
|
20
|
+
end
|
21
|
+
::FileUtils.mkdir_p(::File.dirname(address))
|
22
|
+
end
|
23
|
+
|
24
|
+
#
|
25
|
+
#
|
26
|
+
#
|
27
|
+
def space(name)
|
28
|
+
@spaces[name] ||= Space.new(@db, name)
|
29
|
+
end
|
30
|
+
|
31
|
+
#
|
32
|
+
#
|
33
|
+
#
|
34
|
+
class Space
|
35
|
+
def initalize(db, space)
|
36
|
+
@db = db
|
37
|
+
@space = space
|
38
|
+
@resource = LevelDB::DB.new "#{@db}/#{@space}"
|
39
|
+
end
|
40
|
+
|
41
|
+
def get(entity)
|
42
|
+
Marshal.load(@resource.get(Marshal.dump(key)))
|
43
|
+
end
|
44
|
+
alias :[] :get
|
45
|
+
|
46
|
+
def put(id, entity)
|
47
|
+
@resource.put(Marshal.dump(key), Marshal.dump(entity))
|
48
|
+
end
|
49
|
+
alias :[]= :put
|
50
|
+
|
51
|
+
def find
|
52
|
+
|
53
|
+
end
|
54
|
+
|
55
|
+
def find_all
|
56
|
+
|
57
|
+
end
|
58
|
+
|
59
|
+
def collect
|
60
|
+
|
61
|
+
end
|
62
|
+
|
63
|
+
def sort
|
64
|
+
|
65
|
+
end
|
66
|
+
|
67
|
+
def method_missing(action, *args)
|
68
|
+
@resource.send(action, *args)
|
69
|
+
end # method_missing
|
70
|
+
end # Space
|
71
|
+
end # Leveldb
|
72
|
+
end # Kvs
|
73
|
+
end # UzuUzu
|
@@ -0,0 +1,68 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
# TODO
|
3
|
+
require 'mongo'
|
4
|
+
|
5
|
+
module UzuUzu
|
6
|
+
module Kvs
|
7
|
+
class Mongo
|
8
|
+
#
|
9
|
+
attr_reader :adapter
|
10
|
+
|
11
|
+
#
|
12
|
+
#
|
13
|
+
#
|
14
|
+
def initialize(env=nil)
|
15
|
+
@adapter = :mongo
|
16
|
+
@host = 'localhost'
|
17
|
+
@port = 27017
|
18
|
+
@db_name = 'uzuuzu'
|
19
|
+
@spaces = {}
|
20
|
+
if env
|
21
|
+
@host = env['host'] || @host
|
22
|
+
@port = env['port'] || @port
|
23
|
+
@db_name = env['db'] || @db_name
|
24
|
+
end
|
25
|
+
@connection = Mongo::Connection.new(@host, @port)
|
26
|
+
@db = @connection.db(@db_name)
|
27
|
+
end
|
28
|
+
|
29
|
+
#
|
30
|
+
#
|
31
|
+
#
|
32
|
+
def space(name)
|
33
|
+
@spaces[name] ||= Space.new(@db, name)
|
34
|
+
end
|
35
|
+
|
36
|
+
#
|
37
|
+
#
|
38
|
+
#
|
39
|
+
class Space
|
40
|
+
def initalize(db, space)
|
41
|
+
@db = db
|
42
|
+
@space = space
|
43
|
+
@resource = @db[name]
|
44
|
+
end
|
45
|
+
|
46
|
+
def get(id)
|
47
|
+
|
48
|
+
end
|
49
|
+
|
50
|
+
def put(id, entity)
|
51
|
+
|
52
|
+
end
|
53
|
+
|
54
|
+
def find(params)
|
55
|
+
|
56
|
+
end
|
57
|
+
|
58
|
+
def find_all(params)
|
59
|
+
|
60
|
+
end
|
61
|
+
|
62
|
+
def method_missing(action, *args)
|
63
|
+
@resource.send(action, *args)
|
64
|
+
end # method_missing
|
65
|
+
end # Space
|
66
|
+
end # Mongo
|
67
|
+
end # Kvs
|
68
|
+
end # UzuUzu
|
File without changes
|
File without changes
|
@@ -0,0 +1,51 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
require 'appengine-apis'
|
3
|
+
require 'appengine-apis/logger'
|
4
|
+
|
5
|
+
module UzuUzu
|
6
|
+
module Logger
|
7
|
+
class Appengine
|
8
|
+
#
|
9
|
+
attr_reader :adapter
|
10
|
+
#
|
11
|
+
#
|
12
|
+
#
|
13
|
+
def initialize(env=nil)
|
14
|
+
@adapter = :appengine
|
15
|
+
@logger = AppEngine::Logger.new
|
16
|
+
level = env['level'] || :debug
|
17
|
+
case(level.to_sym)
|
18
|
+
when :info
|
19
|
+
@logger.level = ::Logger::Severity::INFO
|
20
|
+
when :warn
|
21
|
+
@logger.level = ::Logger::Severity::WARN
|
22
|
+
when :error
|
23
|
+
@logger.level = ::Logger::Severity::ERROR
|
24
|
+
when :fatal
|
25
|
+
@logger.level = ::Logger::Severity::FATAL
|
26
|
+
when :unknown
|
27
|
+
@logger.level = ::Logger::Severity::UNKNOWN
|
28
|
+
else
|
29
|
+
@logger.level = ::Logger::Severity::DEBUG
|
30
|
+
end
|
31
|
+
end # initialize
|
32
|
+
#
|
33
|
+
#
|
34
|
+
#
|
35
|
+
def method_missing(action, *args)
|
36
|
+
begin
|
37
|
+
args.each do |message|
|
38
|
+
message = message.to_str if message.respond_to?(:to_str)
|
39
|
+
message = message.inspect unless message.instance_of?(String)
|
40
|
+
@logger.send(action, message)
|
41
|
+
end
|
42
|
+
rescue => e
|
43
|
+
# puts standerd error output
|
44
|
+
$stderr.puts 'logger unknown error'
|
45
|
+
$stderr.puts e
|
46
|
+
end
|
47
|
+
end # method_missing
|
48
|
+
|
49
|
+
end # Appengine
|
50
|
+
end # Logger
|
51
|
+
end # UzuUzu
|
@@ -0,0 +1,50 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
require 'logger'
|
3
|
+
|
4
|
+
module UzuUzu
|
5
|
+
module Logger
|
6
|
+
class File
|
7
|
+
#
|
8
|
+
attr_reader :adapter
|
9
|
+
#
|
10
|
+
#
|
11
|
+
#
|
12
|
+
def initialize(env=nil)
|
13
|
+
@adapter = :file
|
14
|
+
out = env['path']
|
15
|
+
rotate = (env['rotate'] || 0).to_i
|
16
|
+
rotate_size = (env['rotate_size'] || 0).to_i * 1024
|
17
|
+
::FileUtils.mkdir_p(::File.dirname(out))
|
18
|
+
@logger = ::Logger.new(out, rotate, rotate_size)
|
19
|
+
level = env['level'] || :debug
|
20
|
+
case(level.to_sym)
|
21
|
+
when :info
|
22
|
+
@logger.level = ::Logger::Severity::INFO
|
23
|
+
when :warn
|
24
|
+
@logger.level = ::Logger::Severity::WARN
|
25
|
+
when :error
|
26
|
+
@logger.level = ::Logger::Severity::ERROR
|
27
|
+
when :fatal
|
28
|
+
@logger.level = ::Logger::Severity::FATAL
|
29
|
+
when :unknown
|
30
|
+
@logger.level = ::Logger::Severity::UNKNOWN
|
31
|
+
else
|
32
|
+
@logger.level = ::Logger::Severity::DEBUG
|
33
|
+
end
|
34
|
+
end # initialize
|
35
|
+
#
|
36
|
+
#
|
37
|
+
#
|
38
|
+
def method_missing(action, *args)
|
39
|
+
begin
|
40
|
+
@logger.send(action, *args)
|
41
|
+
rescue => e
|
42
|
+
# puts standerd error output
|
43
|
+
$stderr.puts 'logger unknown error'
|
44
|
+
$stderr.puts e
|
45
|
+
end
|
46
|
+
end # method_missing
|
47
|
+
|
48
|
+
end # File
|
49
|
+
end # Logger
|
50
|
+
end # UzuUzu
|
@@ -0,0 +1,47 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
|
3
|
+
module UzuUzu
|
4
|
+
module Logger
|
5
|
+
class Loggers
|
6
|
+
#
|
7
|
+
attr_reader :adapter
|
8
|
+
#
|
9
|
+
#
|
10
|
+
#
|
11
|
+
def initialize(env=nil)
|
12
|
+
@adapter = :loggers
|
13
|
+
@loggers = []
|
14
|
+
unless env
|
15
|
+
return
|
16
|
+
end
|
17
|
+
env.each do |logger_env|
|
18
|
+
adapter = logger_env["adapter"]
|
19
|
+
require "uzuuzu/logger/#{adapter}"
|
20
|
+
adapter_class = eval("::UzuUzu::Logger::#{adapter.camel_case}")
|
21
|
+
logger = adapter_class.new(logger_env)
|
22
|
+
@loggers << logger
|
23
|
+
end
|
24
|
+
end # initialize
|
25
|
+
#
|
26
|
+
#
|
27
|
+
#
|
28
|
+
def method_missing(action, *args)
|
29
|
+
@loggers.each do |logger|
|
30
|
+
begin
|
31
|
+
args.each do |message|
|
32
|
+
message = message.to_str if message.respond_to?(:to_str)
|
33
|
+
message = message.inspect unless message.instance_of?(String)
|
34
|
+
logger.send(action, message)
|
35
|
+
end
|
36
|
+
rescue => e
|
37
|
+
# puts standerd error output
|
38
|
+
$stderr.puts 'logger unknown error'
|
39
|
+
$stderr.puts e
|
40
|
+
$stderr.puts e.backtrace
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end # method_missing
|
44
|
+
|
45
|
+
end # Loggers
|
46
|
+
end # Logger
|
47
|
+
end # UzuUzu
|
@@ -0,0 +1,50 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
require 'logger'
|
3
|
+
|
4
|
+
module UzuUzu
|
5
|
+
module Logger
|
6
|
+
class Stderr
|
7
|
+
#
|
8
|
+
attr_reader :adapter
|
9
|
+
#
|
10
|
+
#
|
11
|
+
#
|
12
|
+
def initialize(env=nil)
|
13
|
+
@adapter = :stderr
|
14
|
+
@logger = ::Logger.new($stderr)
|
15
|
+
level = env['level'] || :debug
|
16
|
+
case(level.to_sym)
|
17
|
+
when :info
|
18
|
+
@logger.level = ::Logger::Severity::INFO
|
19
|
+
when :warn
|
20
|
+
@logger.level = ::Logger::Severity::WARN
|
21
|
+
when :error
|
22
|
+
@logger.level = ::Logger::Severity::ERROR
|
23
|
+
when :fatal
|
24
|
+
@logger.level = ::Logger::Severity::FATAL
|
25
|
+
when :unknown
|
26
|
+
@logger.level = ::Logger::Severity::UNKNOWN
|
27
|
+
else
|
28
|
+
@logger.level = ::Logger::Severity::DEBUG
|
29
|
+
end
|
30
|
+
end # initialize
|
31
|
+
#
|
32
|
+
#
|
33
|
+
#
|
34
|
+
def method_missing(action, *args)
|
35
|
+
begin
|
36
|
+
args.each do |message|
|
37
|
+
message = message.to_str if message.respond_to?(:to_str)
|
38
|
+
message = message.inspect unless message.instance_of?(String)
|
39
|
+
@logger.send(action, message)
|
40
|
+
end
|
41
|
+
rescue => e
|
42
|
+
# puts standerd error output
|
43
|
+
$stderr.puts 'logger unknown error'
|
44
|
+
$stderr.puts e
|
45
|
+
end
|
46
|
+
end # method_missing
|
47
|
+
|
48
|
+
end # Stderr
|
49
|
+
end # Logger
|
50
|
+
end # UzuUzu
|