syslogify 0.0.1

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.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: e20b2dd7d3425d87039ec02e31271cd7f8093fb4
4
+ data.tar.gz: 2df9d2e9e8da20d17799332c38a711eb5823cdca
5
+ SHA512:
6
+ metadata.gz: f8e2903d726c5354d498f6df802872c7ca3d1e1715b0ceb8f4ec7863de8a2a8a31a5b4f0f65d59966f9e492ae0b56307e117e2060b8f4f08f92836f9735379e6
7
+ data.tar.gz: 9acabcc42d12575998d0d89b741c6a9dc6e24f2044c85f5fbe511b43d85d8aeca0be123538678242dd39c51012b37976419a133b1e438fc27e43a45006909d02
data/.gitignore ADDED
@@ -0,0 +1,14 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ *.bundle
11
+ *.so
12
+ *.o
13
+ *.a
14
+ mkmf.log
data/Gemfile ADDED
@@ -0,0 +1,8 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in syslogify.gemspec
4
+ gemspec
5
+
6
+ gem 'pry'
7
+ gem 'pry-nav'
8
+ gem 'pry-remote'
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2014-2015 Julien Letessier
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,47 @@
1
+ # Syslogify
2
+
3
+ Redirects standard output and standard error to syslog.
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ ```ruby
10
+ gem 'syslogify'
11
+ ```
12
+
13
+ And then execute:
14
+
15
+ $ bundle
16
+
17
+ Or install it yourself as:
18
+
19
+ $ gem install syslogify
20
+
21
+ ## Usage
22
+
23
+ As soon as the gem is loaded, output will be diverted. If you wish to delay
24
+ diversion, change your Gemfile to:
25
+
26
+ ```ruby
27
+ gem 'syslogify', require: false
28
+ ```
29
+
30
+ and start and stop diversion at your convenience:
31
+
32
+ ```ruby
33
+ require 'syslogify/forker'
34
+
35
+ Syslogify::Forker.instance.start
36
+ # do stuff
37
+ Syslogify::Forker.instance.stop
38
+ ```
39
+
40
+
41
+ ## Contributing
42
+
43
+ 1. Fork it ( https://github.com/mezis/syslogify/fork )
44
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
45
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
46
+ 4. Push to the branch (`git push origin my-new-feature`)
47
+ 5. Create a new Pull Request
data/Rakefile ADDED
@@ -0,0 +1,2 @@
1
+ require "bundler/gem_tasks"
2
+
@@ -0,0 +1,68 @@
1
+ require 'syslogify/version'
2
+ require 'singleton'
3
+ require 'syslog'
4
+
5
+ module Syslogify
6
+ # Spawns a logger process that takes your stdout and stderr to syslog,
7
+ # by reopening them and piping to the subprocess.
8
+ #
9
+ # Note that the process ID reported in syslog will be that of the logger
10
+ # subprocess.
11
+ #
12
+ class Forker
13
+ include Singleton
14
+
15
+ def initialize
16
+ @pid = nil
17
+ end
18
+
19
+ def start
20
+ return if @pid
21
+
22
+ rd, wr = IO.pipe
23
+ @old_stdout = STDOUT.dup
24
+ @old_stderr = STDERR.dup
25
+
26
+ Syslog.open(_identity, Syslog::LOG_CONS | Syslog::LOG_NDELAY)
27
+ Syslog.log(Syslog::LOG_NOTICE, 'Diverting logs to syslog')
28
+
29
+ @pid = fork do
30
+ STDIN.reopen(rd)
31
+ wr.close
32
+
33
+ while line = STDIN.gets
34
+ Syslog.log(Syslog::LOG_NOTICE, line)
35
+ end
36
+ Syslog.log(Syslog::LOG_NOTICE, 'Shutting down')
37
+ end
38
+
39
+ Syslog.close
40
+
41
+ rd.close
42
+ STDOUT.reopen(wr)
43
+ STDERR.reopen(wr)
44
+ STDOUT.sync = STDERR.sync = true
45
+
46
+ @old_stderr.puts('Check syslog for further messages')
47
+ self
48
+ end
49
+
50
+ def stop
51
+ return unless @pid
52
+ STDOUT.reopen(@old_stdout)
53
+ STDERR.reopen(@old_stderr)
54
+ @old_stdout = @old_stderr = nil
55
+
56
+ Process.kill('TERM', @pid)
57
+ Process.wait(@pid)
58
+ @pid = nil
59
+ self
60
+ end
61
+
62
+ private
63
+
64
+ def _identity
65
+ @identity ||= ENV.fetch('SYSLOG_IDENTITY', File.basename($PROGRAM_NAME))
66
+ end
67
+ end
68
+ end
@@ -0,0 +1,3 @@
1
+ module Syslogify
2
+ VERSION = "0.0.1"
3
+ end
data/lib/syslogify.rb ADDED
@@ -0,0 +1,3 @@
1
+ require 'syslogify/forker'
2
+
3
+ Syslogify::Forker.instance.start
data/syslogify.gemspec ADDED
@@ -0,0 +1,23 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'syslogify/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "syslogify"
8
+ spec.version = Syslogify::VERSION
9
+ spec.authors = ["Julien Letessier"]
10
+ spec.email = ["julien.letessier@gmail.com"]
11
+ spec.summary = %q{Sends stdout and stderr to syslog.}
12
+ spec.description = %q{Sends stdout and stderr to syslog..}
13
+ spec.homepage = "https://github.com/mezis/syslogify"
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0")
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_development_dependency "bundler", "~> 1.7"
22
+ spec.add_development_dependency "rake", "~> 10.0"
23
+ end
metadata ADDED
@@ -0,0 +1,81 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: syslogify
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Julien Letessier
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-01-05 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.7'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.7'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '10.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.0'
41
+ description: Sends stdout and stderr to syslog..
42
+ email:
43
+ - julien.letessier@gmail.com
44
+ executables: []
45
+ extensions: []
46
+ extra_rdoc_files: []
47
+ files:
48
+ - ".gitignore"
49
+ - Gemfile
50
+ - LICENSE.txt
51
+ - README.md
52
+ - Rakefile
53
+ - lib/syslogify.rb
54
+ - lib/syslogify/forker.rb
55
+ - lib/syslogify/version.rb
56
+ - syslogify.gemspec
57
+ homepage: https://github.com/mezis/syslogify
58
+ licenses:
59
+ - MIT
60
+ metadata: {}
61
+ post_install_message:
62
+ rdoc_options: []
63
+ require_paths:
64
+ - lib
65
+ required_ruby_version: !ruby/object:Gem::Requirement
66
+ requirements:
67
+ - - ">="
68
+ - !ruby/object:Gem::Version
69
+ version: '0'
70
+ required_rubygems_version: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - ">="
73
+ - !ruby/object:Gem::Version
74
+ version: '0'
75
+ requirements: []
76
+ rubyforge_project:
77
+ rubygems_version: 2.2.2
78
+ signing_key:
79
+ specification_version: 4
80
+ summary: Sends stdout and stderr to syslog.
81
+ test_files: []