game-server 0.4.1 → 0.4.2
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/game-server.gemspec +2 -2
- data/lib/daemon_logger.rb +25 -1
- metadata +13 -13
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.4.
|
1
|
+
0.4.2
|
data/game-server.gemspec
CHANGED
@@ -5,11 +5,11 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = "game-server"
|
8
|
-
s.version = "0.4.
|
8
|
+
s.version = "0.4.2"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["V_M"]
|
12
|
-
s.date = "2012-06-
|
12
|
+
s.date = "2012-06-29"
|
13
13
|
s.description = "siply general-porpuse game server"
|
14
14
|
s.email = "nobody@nowhere.com"
|
15
15
|
s.extra_rdoc_files = [
|
data/lib/daemon_logger.rb
CHANGED
@@ -1,6 +1,11 @@
|
|
1
|
+
require 'net/smtp'
|
2
|
+
require 'singleton'
|
3
|
+
require 'logger'
|
4
|
+
|
1
5
|
class DaemonLogger
|
2
6
|
include Singleton
|
3
7
|
attr_writer :logger
|
8
|
+
attr_accessor :email_receivers, :smtp_server
|
4
9
|
|
5
10
|
class NullLogger
|
6
11
|
def method_missing(*args, &block)
|
@@ -9,6 +14,10 @@ class DaemonLogger
|
|
9
14
|
end
|
10
15
|
|
11
16
|
|
17
|
+
# ==== Params
|
18
|
+
# params<Hash>::
|
19
|
+
# log_file_path<String>:: куда будет писаться лог
|
20
|
+
# email_receivers<Array[String]>:: список получателей сообщений о критических ошибках
|
12
21
|
def init(params)
|
13
22
|
raise TypeError.new(":log_file_path required") unless params[:log_file_path]
|
14
23
|
file = File.open(params[:log_file_path], 'a')
|
@@ -17,6 +26,8 @@ class DaemonLogger
|
|
17
26
|
logger.level = Logger::DEBUG
|
18
27
|
logger.formatter = Logger::Formatter.new
|
19
28
|
logger.datetime_format = "%y-%m-%d %H:%M:%S.%L"
|
29
|
+
self.email_receivers = params[:email_receivers].to_a
|
30
|
+
self.smtp_server = params[:smtp_server] || 'localhost'
|
20
31
|
end
|
21
32
|
|
22
33
|
def self.init(*params)
|
@@ -32,8 +43,19 @@ class DaemonLogger
|
|
32
43
|
end
|
33
44
|
end
|
34
45
|
|
46
|
+
def send_emails_to_receivers(message)
|
47
|
+
return if !email_receivers or email_receivers.empty?
|
48
|
+
Net::SMTP.start(smtp_server) do |smtp|
|
49
|
+
smtp.send_message message, 'daemon.exceptions@skyburg.com', email_receivers
|
50
|
+
end
|
51
|
+
rescue => e
|
52
|
+
log_exception(e, false, "SENDING EXCEPTION EMAIL ERROR")
|
53
|
+
end
|
54
|
+
|
55
|
+
|
35
56
|
module Mixins
|
36
57
|
|
58
|
+
# FIXME:: DOCUMENTATION
|
37
59
|
def log(message, log_type = :info)
|
38
60
|
puts "#{Time.now} #{log_type} #{message}"
|
39
61
|
DaemonLogger.instance.logger.send(log_type, message)
|
@@ -47,10 +69,11 @@ Exception was raised #{exception}
|
|
47
69
|
BACKTRACE:
|
48
70
|
#{exception.backtrace.join("\n")}
|
49
71
|
EOF
|
50
|
-
|
72
|
+
DaemonLogger.instance.send_emails_to_receivers(message) if send_mail
|
51
73
|
log(message, :error)
|
52
74
|
end
|
53
75
|
|
76
|
+
|
54
77
|
def with_exception_logging
|
55
78
|
yield
|
56
79
|
rescue => e
|
@@ -61,4 +84,5 @@ EOF
|
|
61
84
|
|
62
85
|
end
|
63
86
|
|
87
|
+
include Mixins
|
64
88
|
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: game-server
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.4.
|
4
|
+
version: 0.4.2
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2012-06-
|
12
|
+
date: 2012-06-29 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: shoulda
|
16
|
-
requirement: &
|
16
|
+
requirement: &80314020 !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: :development
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *80314020
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: rdoc
|
27
|
-
requirement: &
|
27
|
+
requirement: &80313590 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ~>
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '3.12'
|
33
33
|
type: :development
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *80313590
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: bundler
|
38
|
-
requirement: &
|
38
|
+
requirement: &80351950 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ~>
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: 1.0.0
|
44
44
|
type: :development
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *80351950
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: jeweler
|
49
|
-
requirement: &
|
49
|
+
requirement: &80351540 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ~>
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: 1.8.3
|
55
55
|
type: :development
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *80351540
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: simplecov
|
60
|
-
requirement: &
|
60
|
+
requirement: &80350760 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ! '>='
|
@@ -65,7 +65,7 @@ dependencies:
|
|
65
65
|
version: '0'
|
66
66
|
type: :development
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *80350760
|
69
69
|
description: siply general-porpuse game server
|
70
70
|
email: nobody@nowhere.com
|
71
71
|
executables: []
|
@@ -109,7 +109,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
109
109
|
version: '0'
|
110
110
|
segments:
|
111
111
|
- 0
|
112
|
-
hash:
|
112
|
+
hash: -949991089
|
113
113
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
114
114
|
none: false
|
115
115
|
requirements:
|