eventhub-processor 0.1.1 → 0.1.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 8e4ce69b4a807077b43ff86fa599cf2f16a98edd
4
- data.tar.gz: 11494b0b12a740701ee3d9485a62cf86bb998554
3
+ metadata.gz: 8dda3a1543220545afd10fcc6466913e0c19e6cb
4
+ data.tar.gz: 411262e7389a5f9c92d716c5c632f3fd42c06077
5
5
  SHA512:
6
- metadata.gz: 6643282458c6a9fda028a66cdd595cfee83a4b0fd4a37bda1b3efc34a7f645c9bd25b87f2cae6020ea15526f4504c70701fd442d0eac662791c8b072451d59bb
7
- data.tar.gz: 4cd12c7edcadf630f7445d6be571fe54e9779a6a09891a726995586b0e1cdc0b0f344222fced136a3d3e85b92dc2c397ef04c6e3e43dc1e968c0459ca9f5d13d
6
+ metadata.gz: fdb8ee6c5fa76437f526229ecf1260c9d285b554c244fbf5a3f8144a46737ecce043bc0f36f9bf156d28a348e283dbd26789632fb7072a4b64e3af0641572ae7
7
+ data.tar.gz: b9356d7fe81a1a3c03266bd8edaede3e5e21c5a00d734a7d268c590037ef3d02327b3354ebf3f766391a876f13eabd79bba5fdb2af9be51f486fa8946dafa303
@@ -16,10 +16,16 @@ module EventHub
16
16
 
17
17
  class MultiLogger
18
18
 
19
+ MAX_EXCEPTIONS_FILES = 500
20
+
19
21
  attr_accessor :folder, :devices
20
22
 
21
23
  def initialize(folder=nil)
22
- @folder = folder || (Dir.pwd + '/log')
24
+ @folder_base = folder || Dir.pwd
25
+ @folder_base.chomp!('/')
26
+ @folder = [@folder_base,'logs'].join('/')
27
+ @folder_exceptions = [@folder_base,'exceptions'].join('/')
28
+
23
29
  @devices = []
24
30
 
25
31
  FileUtils.makedirs(@folder)
@@ -34,9 +40,21 @@ module EventHub
34
40
  stamp = "#{time.strftime("%Y%m%d_%H%M%S")}_#{"%03d" % (time.usec/1000)}"
35
41
  filename = "#{stamp}.log"
36
42
 
37
- FileUtils.makedirs("#{folder}/exceptions")
43
+ FileUtils.makedirs(@folder_exceptions)
44
+
45
+ # check max exception log files
46
+ exception_files = Dir.glob(@folder_exceptions + '/*.log')
47
+ if exception_files.size > MAX_EXCEPTIONS_FILES
48
+ exception_files.reverse[MAX_EXCEPTIONS_FILES..-1].each do |file|
49
+ begin
50
+ File.delete(file)
51
+ File.delete(File.dirname(file) + '/' + File.basename(file,".*") + '.msg.raw')
52
+ rescue
53
+ end
54
+ end
55
+ end
38
56
 
39
- File.open("#{@folder}/exceptions/#{filename}","w") do |output|
57
+ File.open("#{@folder_exceptions}/#{filename}","w") do |output|
40
58
  output.write("#{feedback}\n\n")
41
59
  output.write("Exception: #{feedback.class.to_s}\n\n")
42
60
  output.write("Call Stack:\n")
@@ -47,7 +65,7 @@ module EventHub
47
65
 
48
66
  # save message if provided
49
67
  if message
50
- File.open("#{@folder}/exceptions/#{stamp}.msg.raw","wb") do |output|
68
+ File.open("#{@folder_exceptions}/#{stamp}.msg.raw","wb") do |output|
51
69
  output.write(message)
52
70
  end
53
71
  end
@@ -159,7 +159,7 @@ module EventHub
159
159
  ensure
160
160
  # remove pid file
161
161
  begin
162
- File.delete("#{@folder}/#{@name}.pid")
162
+ File.delete("#{@folder}/pids/#{@name}.pid")
163
163
  rescue
164
164
  # ignore exceptions here
165
165
  end
@@ -281,7 +281,9 @@ module EventHub
281
281
  Process.daemon
282
282
 
283
283
  # write daemon pid
284
- IO.write("#{@folder}/#{@name}.pid",Process.pid.to_s)
284
+ pids_folder = @folder + "/pids"
285
+ FileUtils.makedirs(pids_folder)
286
+ IO.write("#{pids_folder}/#{@name}.pid",Process.pid.to_s)
285
287
  end
286
288
 
287
289
  def post_start
@@ -1,3 +1,3 @@
1
1
  module EventHub
2
- VERSION = "0.1.1"
2
+ VERSION = "0.1.2"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: eventhub-processor
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.1.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Thomas Steiner
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-04-22 00:00:00.000000000 Z
11
+ date: 2014-04-29 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler