fluent-plugin-idobata 0.0.2 → 0.0.3

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: d82aaaab04680e75a9f891f5d4bdead5860e2d1f
4
- data.tar.gz: d42c9e744b69f3ba9b6a288bd10cc136bb55751a
3
+ metadata.gz: 5f6a7ed06f9351a5f84c458d6d7257ebea1a81a5
4
+ data.tar.gz: 05221ac8b43f5822a17abc109dbc5bbcdfe8b85b
5
5
  SHA512:
6
- metadata.gz: 22f40ab9b1d7ab619602944d4e3e52cc1ca89f1563266495340b97081b0c0d89093ae5cc7b2de2c721d81dc9fec0eca5b0e32496810fa65d6acd484c1a2f2d23
7
- data.tar.gz: f0f5701ea282b761f3ac2ab3576685c3654796480969fb4271c865188664d3efefb3abee3ca4fa82b321e4cf6ee8eee5113e6792f329385266de59181caca242
6
+ metadata.gz: efffca3ae696544c1a0ba19194933e943bda1986a7c38c9826473eb7e0459cdb8972fc3b9344195e6c9c38c3c380f1be0b5593e6c86efbff39190893a2d90d12
7
+ data.tar.gz: 083b67d66eac2f7c4fbbec3bdbd4094af3c8d34a947edd0cd66f73797b6dc0675f6d7e1033dfd931429a59144e522eb5dcdb73e4fbaa03c202f21fefee6ca9b9
data/README.md CHANGED
@@ -1,4 +1,4 @@
1
- # fluent-plugin-idobata
1
+ # fluent-plugin-idobata, a plugin for [Fluentd](http://fluentd.org)
2
2
 
3
3
  ## Output
4
4
 
@@ -26,7 +26,7 @@ see: https://idobata.io
26
26
  - You can use erb notation
27
27
  - send message to idobata
28
28
  - (optional)post_interval
29
- - Internal of post to idobata
29
+ - Interval of post to idobata
30
30
 
31
31
  #### example
32
32
 
@@ -4,7 +4,7 @@ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
4
 
5
5
  Gem::Specification.new do |spec|
6
6
  spec.name = "fluent-plugin-idobata"
7
- spec.version = '0.0.2'
7
+ spec.version = '0.0.3'
8
8
  spec.authors = ["bash0C7"]
9
9
  spec.email = ["koshiba+github@4038nullpointer.com"]
10
10
  spec.description = "Fluentd output plugin to send data to idobata"
@@ -1,6 +1,7 @@
1
1
  require 'httparty'
2
2
  require 'erb'
3
3
  require 'ostruct'
4
+ require 'cgi'
4
5
 
5
6
  module Fluent
6
7
  class Fluent::IdobataOutput < Fluent::Output
@@ -58,7 +59,7 @@ module Fluent
58
59
  record = param.record
59
60
 
60
61
  begin
61
- HTTParty.post(@webhook_url, :body => "body=#{@erb.result(binding)}")
62
+ HTTParty.post(@webhook_url, :body => "body=#{CGI.escape(@erb.result(binding))}")
62
63
  sleep(@post_interval)
63
64
  rescue
64
65
  $log.warn "raises exception: #{$!.class}, '#{$!.message}, #{param}'"
@@ -25,31 +25,57 @@ describe do
25
25
  end
26
26
 
27
27
  describe 'emit' do
28
- let(:record1) {{ 'field1' => 50, 'otherfield' => 99}}
29
- let(:record2) {{ 'field1' => 150, 'otherfield' => 199}}
30
28
  let(:time) {0}
31
- let(:posted) {
32
- d = driver
29
+ context 'without semicolon in body' do
30
+ let(:record1) {{ 'field1' => 50, 'otherfield' => 99}}
31
+ let(:record2) {{ 'field1' => 150, 'otherfield' => 199}}
32
+ let(:posted) {
33
+ d = driver
33
34
 
34
- mock(HTTParty).post('https://idobata/web_hook/url', :body => 'body=field1 value: 50')
35
- mock(HTTParty).post('https://idobata/web_hook/url', :body => 'body=field1 value: 150')
35
+ expect(HTTParty).to receive(:post).with('https://idobata/web_hook/url', :body => "body=#{CGI.escape('field1 value: 50')}")
36
+ expect(HTTParty).to receive(:post).with('https://idobata/web_hook/url', :body => "body=#{CGI.escape('field1 value: 150')}")
36
37
 
37
- d.emit(record1, Time.at(time))
38
- d.emit(record2, Time.at(time))
39
- d.run
40
- }
38
+ d.emit(record1, Time.at(time))
39
+ d.emit(record2, Time.at(time))
40
+ d.run
41
+ }
41
42
 
42
- context do
43
- let(:config) {
44
- %[
45
- webhook_url https://idobata/web_hook/url
46
- message_template field1 value: <%= record["field1"] %>
47
- post_interval 0
48
- ]
43
+ context do
44
+ let(:config) {
45
+ %[
46
+ webhook_url https://idobata/web_hook/url
47
+ message_template field1 value: <%= record["field1"] %>
48
+ post_interval 0
49
+ ]
50
+ }
51
+
52
+ subject {posted}
53
+ it{should_not be_nil}
54
+ end
55
+ end
56
+ context 'without semicolon in body' do
57
+ let(:record1) {{ 'field1' => ';te;st;', 'otherfield' => 99}}
58
+ let(:posted) {
59
+ d = driver
60
+
61
+ expect(HTTParty).to receive(:post).with('https://idobata/web_hook/url', :body => "body=#{CGI.escape('field1 value: ;te;st;')}")
62
+
63
+ d.emit(record1, Time.at(time))
64
+ d.run
49
65
  }
50
66
 
51
- subject {posted}
52
- it{should_not be_nil}
67
+ context do
68
+ let(:config) {
69
+ %[
70
+ webhook_url https://idobata/web_hook/url
71
+ message_template field1 value: <%= record["field1"] %>
72
+ post_interval 0
73
+ ]
74
+ }
75
+
76
+ subject {posted}
77
+ it{should_not be_nil}
78
+ end
53
79
  end
54
80
 
55
81
  end
metadata CHANGED
@@ -1,111 +1,111 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: fluent-plugin-idobata
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.2
4
+ version: 0.0.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - bash0C7
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-05-06 00:00:00.000000000 Z
11
+ date: 2014-12-11 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: fluentd
15
15
  requirement: !ruby/object:Gem::Requirement
16
16
  requirements:
17
- - - ">="
17
+ - - '>='
18
18
  - !ruby/object:Gem::Version
19
19
  version: '0'
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
- - - ">="
24
+ - - '>='
25
25
  - !ruby/object:Gem::Version
26
26
  version: '0'
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: httparty
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
- - - "~>"
31
+ - - ~>
32
32
  - !ruby/object:Gem::Version
33
33
  version: '0.13'
34
34
  type: :runtime
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
- - - "~>"
38
+ - - ~>
39
39
  - !ruby/object:Gem::Version
40
40
  version: '0.13'
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: bundler
43
43
  requirement: !ruby/object:Gem::Requirement
44
44
  requirements:
45
- - - "~>"
45
+ - - ~>
46
46
  - !ruby/object:Gem::Version
47
47
  version: '1.3'
48
48
  type: :development
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
- - - "~>"
52
+ - - ~>
53
53
  - !ruby/object:Gem::Version
54
54
  version: '1.3'
55
55
  - !ruby/object:Gem::Dependency
56
56
  name: rake
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
- - - ">="
59
+ - - '>='
60
60
  - !ruby/object:Gem::Version
61
61
  version: '0'
62
62
  type: :development
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
- - - ">="
66
+ - - '>='
67
67
  - !ruby/object:Gem::Version
68
68
  version: '0'
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: rspec
71
71
  requirement: !ruby/object:Gem::Requirement
72
72
  requirements:
73
- - - ">="
73
+ - - '>='
74
74
  - !ruby/object:Gem::Version
75
75
  version: '0'
76
76
  type: :development
77
77
  prerelease: false
78
78
  version_requirements: !ruby/object:Gem::Requirement
79
79
  requirements:
80
- - - ">="
80
+ - - '>='
81
81
  - !ruby/object:Gem::Version
82
82
  version: '0'
83
83
  - !ruby/object:Gem::Dependency
84
84
  name: rr
85
85
  requirement: !ruby/object:Gem::Requirement
86
86
  requirements:
87
- - - ">="
87
+ - - '>='
88
88
  - !ruby/object:Gem::Version
89
89
  version: '0'
90
90
  type: :development
91
91
  prerelease: false
92
92
  version_requirements: !ruby/object:Gem::Requirement
93
93
  requirements:
94
- - - ">="
94
+ - - '>='
95
95
  - !ruby/object:Gem::Version
96
96
  version: '0'
97
97
  - !ruby/object:Gem::Dependency
98
98
  name: pry
99
99
  requirement: !ruby/object:Gem::Requirement
100
100
  requirements:
101
- - - ">="
101
+ - - '>='
102
102
  - !ruby/object:Gem::Version
103
103
  version: '0'
104
104
  type: :development
105
105
  prerelease: false
106
106
  version_requirements: !ruby/object:Gem::Requirement
107
107
  requirements:
108
- - - ">="
108
+ - - '>='
109
109
  - !ruby/object:Gem::Version
110
110
  version: '0'
111
111
  description: Fluentd output plugin to send data to idobata
@@ -115,8 +115,8 @@ executables: []
115
115
  extensions: []
116
116
  extra_rdoc_files: []
117
117
  files:
118
- - ".gitignore"
119
- - ".rspec"
118
+ - .gitignore
119
+ - .rspec
120
120
  - Gemfile
121
121
  - README.md
122
122
  - Rakefile
@@ -134,17 +134,17 @@ require_paths:
134
134
  - lib
135
135
  required_ruby_version: !ruby/object:Gem::Requirement
136
136
  requirements:
137
- - - ">="
137
+ - - '>='
138
138
  - !ruby/object:Gem::Version
139
139
  version: '0'
140
140
  required_rubygems_version: !ruby/object:Gem::Requirement
141
141
  requirements:
142
- - - ">="
142
+ - - '>='
143
143
  - !ruby/object:Gem::Version
144
144
  version: '0'
145
145
  requirements: []
146
146
  rubyforge_project:
147
- rubygems_version: 2.2.0
147
+ rubygems_version: 2.0.14
148
148
  signing_key:
149
149
  specification_version: 4
150
150
  summary: Fluentd output plugin to send data to idobata