tail_f_rabbitmq 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 987baab2c19e3419f7ed92bf39a4eb2c9e9db095
4
+ data.tar.gz: 50051eee353e6937fef99e2d449a151078569157
5
+ SHA512:
6
+ metadata.gz: f9ad1f598fc87e77bde6168f9763579785b7971efa3558057b50fffca9bbfedfc58179f87e24773907048ff22223889cac3086f143392f41918c9aaaa84c9be1
7
+ data.tar.gz: 63b519bc7aa8cb4b0ccc6d878e62a556a89db81f3a21b994085614834913c44229fb2f62dfef04cea49e377dbbafe742a54c9b40c8d0c356c392bbb558488142
data/.gitignore ADDED
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://ruby.taobao.org'
2
+
3
+ # Specify your gem's dependencies in tail_f_rabbitmq.gemspec
4
+ gemspec
data/README.md ADDED
@@ -0,0 +1,36 @@
1
+ # TailFRabbitmq
2
+
3
+ Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/tail_f_rabbitmq`. To experiment with that code, run `bin/console` for an interactive prompt.
4
+
5
+ TODO: Delete this and the text above, and describe your gem
6
+
7
+ ## Installation
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ ```ruby
12
+ gem 'tail_f_rabbitmq'
13
+ ```
14
+
15
+ And then execute:
16
+
17
+ $ bundle
18
+
19
+ Or install it yourself as:
20
+
21
+ $ gem install tail_f_rabbitmq
22
+
23
+ ## Usage
24
+
25
+ TODO: Write usage instructions here
26
+
27
+ ## Development
28
+
29
+ After checking out the repo, run `bin/setup` to install dependencies. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
+
31
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
+
33
+ ## Contributing
34
+
35
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/tail_f_rabbitmq.
36
+
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "tail_f_rabbitmq"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
data/bin/fir_tail_f ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+ # encoding: utf-8
3
+
4
+ require_relative '../lib/tail_f_rabbitmq'
5
+
6
+ begin
7
+ OS.set_locale
8
+ FIR::CLI.start ARGV
9
+ rescue Exception => e
10
+ STDERR.puts e.message
11
+ STDERR.puts e.backtrace.join("\n")
12
+ exit 1
13
+ end
14
+
data/bin/setup ADDED
@@ -0,0 +1,7 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+
5
+ bundle install
6
+
7
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,19 @@
1
+ module FIR
2
+ class CLI < Thor
3
+ desc 'monitor', 'monitor directoy'
4
+ def monitor(*args)
5
+ TailFRabbitmq.monitor(args.first)
6
+ end
7
+
8
+ desc "reset", "reset config"
9
+ def reset
10
+ TailFRabbitmq.reset_config
11
+ end
12
+
13
+ desc 'help', 'Describe available commands or one specific command (aliases: `h`).'
14
+ map Thor::HELP_MAPPINGS => :help
15
+ def help(command = nil, subcommand = false)
16
+ super
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,148 @@
1
+ # encoding: utf-8
2
+
3
+ module ActiveSupport
4
+ # A typical module looks like this:
5
+ #
6
+ # module M
7
+ # def self.included(base)
8
+ # base.extend ClassMethods
9
+ # base.class_eval do
10
+ # scope :disabled, -> { where(disabled: true) }
11
+ # end
12
+ # end
13
+ #
14
+ # module ClassMethods
15
+ # ...
16
+ # end
17
+ # end
18
+ #
19
+ # By using <tt>ActiveSupport::Concern</tt> the above module could instead be
20
+ # written as:
21
+ #
22
+ # require 'active_support/concern'
23
+ #
24
+ # module M
25
+ # extend ActiveSupport::Concern
26
+ #
27
+ # included do
28
+ # scope :disabled, -> { where(disabled: true) }
29
+ # end
30
+ #
31
+ # class_methods do
32
+ # ...
33
+ # end
34
+ # end
35
+ #
36
+ # Moreover, it gracefully handles module dependencies. Given a +Foo+ module
37
+ # and a +Bar+ module which depends on the former, we would typically write the
38
+ # following:
39
+ #
40
+ # module Foo
41
+ # def self.included(base)
42
+ # base.class_eval do
43
+ # def self.method_injected_by_foo
44
+ # ...
45
+ # end
46
+ # end
47
+ # end
48
+ # end
49
+ #
50
+ # module Bar
51
+ # def self.included(base)
52
+ # base.method_injected_by_foo
53
+ # end
54
+ # end
55
+ #
56
+ # class Host
57
+ # include Foo # We need to include this dependency for Bar
58
+ # include Bar # Bar is the module that Host really needs
59
+ # end
60
+ #
61
+ # But why should +Host+ care about +Bar+'s dependencies, namely +Foo+? We
62
+ # could try to hide these from +Host+ directly including +Foo+ in +Bar+:
63
+ #
64
+ # module Bar
65
+ # include Foo
66
+ # def self.included(base)
67
+ # base.method_injected_by_foo
68
+ # end
69
+ # end
70
+ #
71
+ # class Host
72
+ # include Bar
73
+ # end
74
+ #
75
+ # Unfortunately this won't work, since when +Foo+ is included, its <tt>base</tt>
76
+ # is the +Bar+ module, not the +Host+ class. With <tt>ActiveSupport::Concern</tt>,
77
+ # module dependencies are properly resolved:
78
+ #
79
+ # require 'active_support/concern'
80
+ #
81
+ # module Foo
82
+ # extend ActiveSupport::Concern
83
+ # included do
84
+ # def self.method_injected_by_foo
85
+ # ...
86
+ # end
87
+ # end
88
+ # end
89
+ #
90
+ # module Bar
91
+ # extend ActiveSupport::Concern
92
+ # include Foo
93
+ #
94
+ # included do
95
+ # self.method_injected_by_foo
96
+ # end
97
+ # end
98
+ #
99
+ # class Host
100
+ # include Bar # It works, now Bar takes care of its dependencies
101
+ # end
102
+ module Concern
103
+ class MultipleIncludedBlocks < StandardError #:nodoc:
104
+ def initialize
105
+ super "Cannot define multiple 'included' blocks for a Concern"
106
+ end
107
+ end
108
+
109
+ def self.extended(base) #:nodoc:
110
+ base.instance_variable_set(:@_dependencies, [])
111
+ end
112
+
113
+ def append_features(base)
114
+ if base.instance_variable_defined?(:@_dependencies)
115
+ base.instance_variable_get(:@_dependencies) << self
116
+ return false
117
+ else
118
+ return false if base < self
119
+ @_dependencies.each { |dep| base.send(:include, dep) }
120
+ super
121
+ base.extend const_get(:ClassMethods) if const_defined?(:ClassMethods)
122
+ base.class_eval(&@_included_block) if instance_variable_defined?(:@_included_block)
123
+ end
124
+ end
125
+
126
+ def included(base = nil, &block)
127
+ if base.nil?
128
+ fail MultipleIncludedBlocks if instance_variable_defined?(:@_included_block)
129
+
130
+ @_included_block = block
131
+ else
132
+ super
133
+ end
134
+ end
135
+
136
+ def class_methods(&class_methods_module_definition)
137
+ if const_defined?(:ClassMethods, false)
138
+ mod = const_get(:ClassMethods)
139
+ else
140
+ mod = const_set(:ClassMethods, Module.new)
141
+ end
142
+
143
+ mod.module_eval(&class_methods_module_definition)
144
+ end
145
+ end
146
+ end
147
+
148
+
@@ -0,0 +1,227 @@
1
+ # encoding: utf-8
2
+
3
+ class Object
4
+ # An object is blank if it's false, empty, or a whitespace string.
5
+ # For example, '', ' ', +nil+, [], and {} are all blank.
6
+ #
7
+ # This simplifies
8
+ #
9
+ # address.nil? || address.empty?
10
+ #
11
+ # to
12
+ #
13
+ # address.blank?
14
+ #
15
+ # @return [true, false]
16
+ def blank?
17
+ respond_to?(:empty?) ? empty? : !self
18
+ end
19
+
20
+ # An object is present if it's not blank.
21
+ #
22
+ # @return [true, false]
23
+ def present?
24
+ !blank?
25
+ end
26
+
27
+ # Returns the receiver if it's present otherwise returns +nil+.
28
+ # <tt>object.presence</tt> is equivalent to
29
+ #
30
+ # object.present? ? object : nil
31
+ #
32
+ # For example, something like
33
+ #
34
+ # state = params[:state] if params[:state].present?
35
+ # country = params[:country] if params[:country].present?
36
+ # region = state || country || 'US'
37
+ #
38
+ # becomes
39
+ #
40
+ # region = params[:state].presence || params[:country].presence || 'US'
41
+ #
42
+ # @return [Object]
43
+ def presence
44
+ self if present?
45
+ end
46
+ end
47
+
48
+ class NilClass
49
+ # +nil+ is blank:
50
+ #
51
+ # nil.blank? # => true
52
+ #
53
+ # @return [true]
54
+ def blank?
55
+ true
56
+ end
57
+ end
58
+
59
+ class FalseClass
60
+ # +false+ is blank:
61
+ #
62
+ # false.blank? # => true
63
+ #
64
+ # @return [true]
65
+ def blank?
66
+ true
67
+ end
68
+ end
69
+
70
+ class TrueClass
71
+ # +true+ is not blank:
72
+ #
73
+ # true.blank? # => false
74
+ #
75
+ # @return [false]
76
+ def blank?
77
+ false
78
+ end
79
+ end
80
+
81
+ class Array
82
+ # An array is blank if it's empty:
83
+ #
84
+ # [].blank? # => true
85
+ # [1,2,3].blank? # => false
86
+ #
87
+ # @return [true, false]
88
+ alias_method :blank?, :empty?
89
+ end
90
+
91
+ class Hash
92
+ # A hash is blank if it's empty:
93
+ #
94
+ # {}.blank? # => true
95
+ # { key: 'value' }.blank? # => false
96
+ #
97
+ # @return [true, false]
98
+ alias_method :blank?, :empty?
99
+ end
100
+
101
+ class String
102
+ BLANK_RE = /\A[[:space:]]*\z/
103
+
104
+ # A string is blank if it's empty or contains whitespaces only:
105
+ #
106
+ # ''.blank? # => true
107
+ # ' '.blank? # => true
108
+ # "\t\n\r".blank? # => true
109
+ # ' blah '.blank? # => false
110
+ #
111
+ # Unicode whitespace is supported:
112
+ #
113
+ # "\u00a0".blank? # => true
114
+ #
115
+ # @return [true, false]
116
+ def blank?
117
+ BLANK_RE === self
118
+ end
119
+ end
120
+
121
+ class Numeric #:nodoc:
122
+ # No number is blank:
123
+ #
124
+ # 1.blank? # => false
125
+ # 0.blank? # => false
126
+ #
127
+ # @return [false]
128
+ def blank?
129
+ false
130
+ end
131
+ end
132
+
133
+ class Hash
134
+ # Returns a new hash with all keys converted using the block operation.
135
+ #
136
+ # hash = { name: 'Rob', age: '28' }
137
+ #
138
+ # hash.transform_keys{ |key| key.to_s.upcase }
139
+ # # => {"NAME"=>"Rob", "AGE"=>"28"}
140
+ def transform_keys
141
+ return enum_for(:transform_keys) unless block_given?
142
+ result = self.class.new
143
+ each_key do |key|
144
+ result[yield(key)] = self[key]
145
+ end
146
+ result
147
+ end
148
+
149
+ # Returns a new hash with all keys converted to symbols, as long as
150
+ # they respond to +to_sym+.
151
+ #
152
+ # hash = { 'name' => 'Rob', 'age' => '28' }
153
+ #
154
+ # hash.symbolize_keys
155
+ # # => {:name=>"Rob", :age=>"28"}
156
+ def symbolize_keys
157
+ transform_keys { |key| key.to_sym rescue key }
158
+ end
159
+
160
+ # Returns a new hash with all keys converted by the block operation.
161
+ # This includes the keys from the root hash and from all
162
+ # nested hashes and arrays.
163
+ #
164
+ # hash = { person: { name: 'Rob', age: '28' } }
165
+ #
166
+ # hash.deep_transform_keys{ |key| key.to_s.upcase }
167
+ # # => {"PERSON"=>{"NAME"=>"Rob", "AGE"=>"28"}}
168
+ def deep_transform_keys(&block)
169
+ _deep_transform_keys_in_object(self, &block)
170
+ end
171
+
172
+ # Returns a new hash with all keys converted to symbols, as long as
173
+ # they respond to +to_sym+. This includes the keys from the root hash
174
+ # and from all nested hashes and arrays.
175
+ #
176
+ # hash = { 'person' => { 'name' => 'Rob', 'age' => '28' } }
177
+ #
178
+ # hash.deep_symbolize_keys
179
+ # # => {:person=>{:name=>"Rob", :age=>"28"}}
180
+ def deep_symbolize_keys
181
+ deep_transform_keys { |key| key.to_sym rescue key }
182
+ end
183
+
184
+ private
185
+
186
+ # support methods for deep transforming nested hashes and arrays
187
+ def _deep_transform_keys_in_object(object, &block)
188
+ case object
189
+ when Hash
190
+ object.each_with_object({}) do |(key, value), result|
191
+ result[yield(key)] = _deep_transform_keys_in_object(value, &block)
192
+ end
193
+ when Array
194
+ object.map { |e| _deep_transform_keys_in_object(e, &block) }
195
+ else
196
+ object
197
+ end
198
+ end
199
+ end
200
+
201
+ class File
202
+ class << self
203
+ # A binary file is Mach-O dSYM
204
+ #
205
+ # @return [true, false]
206
+ def dsym?(file_path)
207
+ !(`file -b #{file_path}` =~ /dSYM/).nil?
208
+ end
209
+
210
+ # A file is ASCII text
211
+ #
212
+ # @return [true, false]
213
+ def text?(file_path)
214
+ !(`file -b #{file_path}` =~ /text/).nil?
215
+ end
216
+ end
217
+ end
218
+
219
+ class String
220
+ # Convert String encoding to UTF-8
221
+ #
222
+ # @return string
223
+ def to_utf8
224
+ encode(Encoding.find('UTF-8'), invalid: :replace, undef: :replace, replace: '')
225
+ end
226
+ end
227
+
@@ -0,0 +1,29 @@
1
+ # encoding: utf-8
2
+
3
+ module OS
4
+ class << self
5
+
6
+ def windows?
7
+ !(/cygwin|mswin|mingw|bccwin|wince|emx/ =~ RUBY_PLATFORM).nil?
8
+ end
9
+
10
+ def mac?
11
+ !(/darwin/ =~ RUBY_PLATFORM).nil?
12
+ end
13
+
14
+ def unix?
15
+ !OS.windows?
16
+ end
17
+
18
+ def linux?
19
+ OS.unix? && !OS.mac?
20
+ end
21
+
22
+ def set_locale
23
+ system 'export LC_ALL=en_US.UTF-8'
24
+ system 'export LC_CTYPE=en_US.UTF-8'
25
+ system 'export LANG=en_US.UTF-8'
26
+ end
27
+ end
28
+ end
29
+
@@ -0,0 +1,3 @@
1
+ require_relative './patches/concern'
2
+ require_relative './patches/native_patch'
3
+ require_relative './patches/os_patch'
@@ -0,0 +1,36 @@
1
+ # encoding: utf-8
2
+
3
+ module FIR
4
+ module Config
5
+ CONFIG_PATH = "#{ENV['HOME']}/.tail_f_rabbitmq_config"
6
+ def default_config
7
+ config = {
8
+ url: "amqp://guest:guest@localhost:5672",
9
+ queue: "log_line",
10
+ eof: "END"
11
+ }
12
+ end
13
+
14
+ def config
15
+ unless File.exist?(CONFIG_PATH)
16
+ @config = default_config
17
+ write_config @config
18
+ end
19
+ @config ||= YAML.load_file(CONFIG_PATH).deep_symbolize_keys
20
+ end
21
+
22
+ def reload_config
23
+ @config = YAML.load_file(CONFIG_PATH).deep_symbolize_keys
24
+ end
25
+
26
+ def write_config(hash)
27
+ File.open(CONFIG_PATH, 'w+') { |f| f << YAML.dump(hash) }
28
+ end
29
+
30
+ def reset_config
31
+ @config = default_config
32
+ write_config @config
33
+ end
34
+ end
35
+ end
36
+
@@ -0,0 +1,50 @@
1
+ require 'json'
2
+ require 'rb-inotify'
3
+ require_relative './util/config'
4
+ module FIR
5
+ module Util
6
+ extend ActiveSupport::Concern
7
+
8
+ module ClassMethods
9
+ include FIR::Config
10
+
11
+ def monitor file_path
12
+ @conn = Bunny.new(config[:url])
13
+ @conn.start
14
+ @ch = @conn.create_channel
15
+ @q = @ch.queue(config[:queue], :auto_delete => true)
16
+ @x = @ch.default_exchange
17
+ notifier = INotify::Notifier.new
18
+ notifier.watch file_path, :create, :recursive do |event|
19
+ Thread.new do
20
+ tail_f event.absolute_name do |lines, queue|
21
+ send_msg event.name, lines
22
+ queue.stop if lines.include? config[:eof]
23
+ end
24
+ end
25
+ end
26
+ notifier.run
27
+ end
28
+
29
+ def tail_f file_path
30
+ queue = INotify::Notifier.new
31
+ open(file_path) do |file|
32
+ yield file.read, queue # 先处理一次(create 时候的数据)
33
+ queue.watch(file_path, :modify) do
34
+ yield file.read, queue
35
+ end
36
+ queue.run
37
+ end
38
+ end
39
+
40
+ def send_msg(name, line)
41
+ msg = {
42
+ name: name,
43
+ line: line
44
+ }
45
+ @x.publish(msg.to_json, :routing_key => @q.name) if line != ""
46
+ end
47
+ end
48
+ end
49
+ end
50
+
@@ -0,0 +1,3 @@
1
+ module TailFRabbitmq
2
+ VERSION = "0.1.0"
3
+ end
@@ -0,0 +1,13 @@
1
+ require_relative "./tail_f_rabbitmq/version"
2
+ require 'yaml'
3
+ require 'thor'
4
+ require 'bunny'
5
+ require_relative "./tail_f_rabbitmq/patches"
6
+ require_relative "./tail_f_rabbitmq/util"
7
+ require_relative "./tail_f_rabbitmq/cli"
8
+
9
+ module TailFRabbitmq
10
+ include FIR::Util
11
+ end
12
+
13
+ FIR::CLI.start ARGV
@@ -0,0 +1,35 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'tail_f_rabbitmq/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "tail_f_rabbitmq"
8
+ spec.version = TailFRabbitmq::VERSION
9
+ spec.authors = ["atpking"]
10
+ spec.email = ["atpking@gmail.com"]
11
+
12
+ spec.summary = %q{tail_f directory and send to rabbitmq}
13
+ spec.description = %q{like tail -f command, this gem should caputre the change of files and send it to rabbitmq}
14
+
15
+ # Prevent pushing this gem to RubyGems.org by setting 'allowed_push_host', or
16
+ # delete this section to allow pushing this gem to any host.
17
+ if spec.respond_to?(:metadata)
18
+ spec.metadata['allowed_push_host'] = "https://rubygems.org"
19
+ else
20
+ raise "RubyGems 2.0 or newer is required to protect against public gem pushes."
21
+ end
22
+
23
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
24
+ spec.bindir = "bin"
25
+ # spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
26
+ spec.executables = ["fir_tail_f"]
27
+ spec.require_paths = ["lib"]
28
+
29
+ spec.add_development_dependency "bundler", "~> 1.10"
30
+ spec.add_development_dependency "rake"
31
+ spec.add_development_dependency "thor"
32
+ spec.add_development_dependency "json"
33
+ spec.add_development_dependency "rb-inotify"
34
+ spec.add_development_dependency "bunny"
35
+ end
metadata ADDED
@@ -0,0 +1,148 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: tail_f_rabbitmq
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - atpking
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-12-29 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.10'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.10'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: thor
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: json
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rb-inotify
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: bunny
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ description: like tail -f command, this gem should caputre the change of files and
98
+ send it to rabbitmq
99
+ email:
100
+ - atpking@gmail.com
101
+ executables:
102
+ - fir_tail_f
103
+ extensions: []
104
+ extra_rdoc_files: []
105
+ files:
106
+ - ".gitignore"
107
+ - Gemfile
108
+ - README.md
109
+ - Rakefile
110
+ - bin/console
111
+ - bin/fir_tail_f
112
+ - bin/setup
113
+ - lib/tail_f_rabbitmq.rb
114
+ - lib/tail_f_rabbitmq/cli.rb
115
+ - lib/tail_f_rabbitmq/patches.rb
116
+ - lib/tail_f_rabbitmq/patches/concern.rb
117
+ - lib/tail_f_rabbitmq/patches/native_patch.rb
118
+ - lib/tail_f_rabbitmq/patches/os_patch.rb
119
+ - lib/tail_f_rabbitmq/util.rb
120
+ - lib/tail_f_rabbitmq/util/config.rb
121
+ - lib/tail_f_rabbitmq/version.rb
122
+ - tail_f_rabbitmq.gemspec
123
+ homepage:
124
+ licenses: []
125
+ metadata:
126
+ allowed_push_host: https://rubygems.org
127
+ post_install_message:
128
+ rdoc_options: []
129
+ require_paths:
130
+ - lib
131
+ required_ruby_version: !ruby/object:Gem::Requirement
132
+ requirements:
133
+ - - ">="
134
+ - !ruby/object:Gem::Version
135
+ version: '0'
136
+ required_rubygems_version: !ruby/object:Gem::Requirement
137
+ requirements:
138
+ - - ">="
139
+ - !ruby/object:Gem::Version
140
+ version: '0'
141
+ requirements: []
142
+ rubyforge_project:
143
+ rubygems_version: 2.4.6
144
+ signing_key:
145
+ specification_version: 4
146
+ summary: tail_f directory and send to rabbitmq
147
+ test_files: []
148
+ has_rdoc: