magic_pipe 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (42) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +11 -0
  3. data/.rspec +3 -0
  4. data/.travis.yml +8 -0
  5. data/CHANGELOG.md +10 -0
  6. data/Gemfile +6 -0
  7. data/Gemfile.lock +92 -0
  8. data/LICENSE.txt +19 -0
  9. data/README.md +241 -0
  10. data/Rakefile +6 -0
  11. data/bin/console +16 -0
  12. data/bin/setup +8 -0
  13. data/lib/magic_pipe.rb +45 -0
  14. data/lib/magic_pipe/client.rb +41 -0
  15. data/lib/magic_pipe/codecs.rb +24 -0
  16. data/lib/magic_pipe/codecs/base.rb +26 -0
  17. data/lib/magic_pipe/codecs/json.rb +38 -0
  18. data/lib/magic_pipe/codecs/message_pack.rb +81 -0
  19. data/lib/magic_pipe/codecs/thrift.rb +17 -0
  20. data/lib/magic_pipe/codecs/yaml.rb +18 -0
  21. data/lib/magic_pipe/config.rb +103 -0
  22. data/lib/magic_pipe/envelope.rb +29 -0
  23. data/lib/magic_pipe/errors.rb +14 -0
  24. data/lib/magic_pipe/loaders.rb +22 -0
  25. data/lib/magic_pipe/loaders/simple_active_record.rb +54 -0
  26. data/lib/magic_pipe/metrics.rb +54 -0
  27. data/lib/magic_pipe/senders.rb +23 -0
  28. data/lib/magic_pipe/senders/async.rb +76 -0
  29. data/lib/magic_pipe/senders/base.rb +24 -0
  30. data/lib/magic_pipe/senders/metrics_mixin.rb +20 -0
  31. data/lib/magic_pipe/senders/sync.rb +38 -0
  32. data/lib/magic_pipe/transports.rb +26 -0
  33. data/lib/magic_pipe/transports/base.rb +17 -0
  34. data/lib/magic_pipe/transports/debug.rb +17 -0
  35. data/lib/magic_pipe/transports/https.rb +80 -0
  36. data/lib/magic_pipe/transports/kafka.rb +8 -0
  37. data/lib/magic_pipe/transports/log.rb +15 -0
  38. data/lib/magic_pipe/transports/multi.rb +44 -0
  39. data/lib/magic_pipe/transports/sqs.rb +68 -0
  40. data/lib/magic_pipe/version.rb +3 -0
  41. data/magic_pipe.gemspec +44 -0
  42. metadata +257 -0
@@ -0,0 +1,8 @@
1
+ require "magic_pipe/transports/base"
2
+
3
+ module MagicPipe
4
+ module Transports
5
+ class Kafka < Base
6
+ end
7
+ end
8
+ end
@@ -0,0 +1,15 @@
1
+ require "magic_pipe/transports/base"
2
+
3
+ module MagicPipe
4
+ module Transports
5
+ class Log < Base
6
+ def initialize(config, metrics)
7
+ super(config, metrics)
8
+ end
9
+
10
+ def submit(payload, _metadata)
11
+ @logger.info "[Trasport#submit]: ↩️\n#{payload}\n"
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,44 @@
1
+ require "magic_pipe/transports/base"
2
+
3
+ module MagicPipe
4
+ module Transports
5
+ class Multi < Base
6
+ def initialize(config, metrics)
7
+ super(config, metrics)
8
+ @transports = build_nested_transports
9
+ end
10
+
11
+
12
+ def submit(payload, metadata)
13
+ @transports.map do |transport|
14
+ begin
15
+ transport.submit(payload, metadata)
16
+ rescue => e
17
+ log_error(e, transport)
18
+ end
19
+ end
20
+ end
21
+
22
+
23
+ private
24
+
25
+
26
+ def build_nested_transports
27
+ @config.transport.map do |transport|
28
+ klass = MagicPipe::Transports.lookup(transport)
29
+ klass.new(@config, @metrics)
30
+ end
31
+ end
32
+
33
+
34
+ def log_error(e, transport)
35
+ @logger.error(
36
+ "[MagicPipe] Transports::Multi, error submitting with %{t} (%{e})." % {
37
+ t: transport.class,
38
+ e: e
39
+ }
40
+ )
41
+ end
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,68 @@
1
+ require "magic_pipe/transports/base"
2
+
3
+ require "aws-sdk-sqs"
4
+
5
+ # https://docs.aws.amazon.com/sdk-for-ruby/v3/api/Aws/SQS.html
6
+ # https://docs.aws.amazon.com/sdk-for-ruby/v3/api/Aws/SQS/Client.html
7
+
8
+ module MagicPipe
9
+ module Transports
10
+ class Sqs < Base
11
+ def initialize(config, metrics)
12
+ super(config, metrics)
13
+ @options = @config.sqs_transport_options
14
+ @client = Aws::SQS::Client.new
15
+ end
16
+
17
+
18
+ def submit(payload, metadata)
19
+ send_message(payload, metadata)
20
+ end
21
+
22
+
23
+ private
24
+
25
+
26
+ def queue_name
27
+ @options.fetch(:queue)
28
+ end
29
+
30
+
31
+ def queue_url
32
+ @queue_url ||= @client.get_queue_url(queue_name: queue_name).queue_url
33
+ end
34
+
35
+
36
+ def send_message(payload, metadata)
37
+ @client.send_message({
38
+ queue_url: queue_url, # required
39
+ message_body: payload, # required
40
+ delay_seconds: 0,
41
+ message_attributes: meta_attributes(metadata)
42
+ })
43
+ end
44
+
45
+
46
+ def meta_attributes(metadata)
47
+ {
48
+ "topic" => {
49
+ string_value: metadata[:topic],
50
+ data_type: "String", # required
51
+ },
52
+ "producer" => {
53
+ string_value: metadata[:producer],
54
+ data_type: "String", # required
55
+ },
56
+ "sent_at" => {
57
+ string_value: metadata[:time].to_s,
58
+ data_type: "Number", # required
59
+ },
60
+ "mime" => {
61
+ string_value: metadata[:mime],
62
+ data_type: "String", # required
63
+ },
64
+ }
65
+ end
66
+ end
67
+ end
68
+ end
@@ -0,0 +1,3 @@
1
+ module MagicPipe
2
+ VERSION = "0.1.0"
3
+ end
@@ -0,0 +1,44 @@
1
+ lib = File.expand_path("../lib", __FILE__)
2
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
+ require "magic_pipe/version"
4
+
5
+ Gem::Specification.new do |spec|
6
+ spec.name = "magic_pipe"
7
+ spec.version = MagicPipe::VERSION
8
+ spec.authors = ["Tommaso Pavese"]
9
+ spec.email = ["tommaso@pavese.me"]
10
+
11
+ spec.licenses = ['MIT']
12
+
13
+ spec.summary = %q{A Magic Pipe to send data in arbitrary formats to configurable backends, with topics.}
14
+
15
+ spec.description = %q{A Magic Pipe to send data in arbitrary formats to configurable backends, with topics.} +
16
+ %q{ It features a modular design that allows to configure and extend how the payloads are} +
17
+ %q{ fetched, serialized, encoded, submitted, and most importantly where: SQS, HTTPS} +
18
+ %q{ endpoints, etc.}
19
+
20
+ spec.homepage = "https://github.com/tompave/magic_pipe"
21
+
22
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
23
+ f.match(%r{^(test|spec|features)/})
24
+ end
25
+ spec.bindir = "exe"
26
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
27
+ spec.require_paths = ["lib"]
28
+
29
+ spec.add_development_dependency "bundler", "~> 1.16"
30
+ spec.add_development_dependency "rake", "~> 10.0"
31
+ spec.add_development_dependency "pry", '~> 0.11'
32
+
33
+ spec.add_development_dependency "rspec", "~> 3.0"
34
+ spec.add_development_dependency 'webmock', '~> 3.3'
35
+ spec.add_development_dependency 'timecop', '~> 0.9'
36
+
37
+ # Optional dependencies for the adapters
38
+ spec.add_development_dependency 'sidekiq'
39
+ spec.add_development_dependency 'oj'
40
+ spec.add_development_dependency 'msgpack'
41
+ spec.add_development_dependency 'typhoeus'
42
+ spec.add_development_dependency 'faraday'
43
+ spec.add_development_dependency 'aws-sdk-sqs', '~> 1.3'
44
+ end
metadata ADDED
@@ -0,0 +1,257 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: magic_pipe
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Tommaso Pavese
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2018-02-04 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.16'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.16'
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
+ - !ruby/object:Gem::Dependency
42
+ name: pry
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '0.11'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '0.11'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '3.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '3.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: webmock
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '3.3'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '3.3'
83
+ - !ruby/object:Gem::Dependency
84
+ name: timecop
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: '0.9'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: '0.9'
97
+ - !ruby/object:Gem::Dependency
98
+ name: sidekiq
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: oj
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: msgpack
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: typhoeus
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - ">="
144
+ - !ruby/object:Gem::Version
145
+ version: '0'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - ">="
151
+ - !ruby/object:Gem::Version
152
+ version: '0'
153
+ - !ruby/object:Gem::Dependency
154
+ name: faraday
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - ">="
158
+ - !ruby/object:Gem::Version
159
+ version: '0'
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - ">="
165
+ - !ruby/object:Gem::Version
166
+ version: '0'
167
+ - !ruby/object:Gem::Dependency
168
+ name: aws-sdk-sqs
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - "~>"
172
+ - !ruby/object:Gem::Version
173
+ version: '1.3'
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - "~>"
179
+ - !ruby/object:Gem::Version
180
+ version: '1.3'
181
+ description: 'A Magic Pipe to send data in arbitrary formats to configurable backends,
182
+ with topics. It features a modular design that allows to configure and extend how
183
+ the payloads are fetched, serialized, encoded, submitted, and most importantly where:
184
+ SQS, HTTPS endpoints, etc.'
185
+ email:
186
+ - tommaso@pavese.me
187
+ executables: []
188
+ extensions: []
189
+ extra_rdoc_files: []
190
+ files:
191
+ - ".gitignore"
192
+ - ".rspec"
193
+ - ".travis.yml"
194
+ - CHANGELOG.md
195
+ - Gemfile
196
+ - Gemfile.lock
197
+ - LICENSE.txt
198
+ - README.md
199
+ - Rakefile
200
+ - bin/console
201
+ - bin/setup
202
+ - lib/magic_pipe.rb
203
+ - lib/magic_pipe/client.rb
204
+ - lib/magic_pipe/codecs.rb
205
+ - lib/magic_pipe/codecs/base.rb
206
+ - lib/magic_pipe/codecs/json.rb
207
+ - lib/magic_pipe/codecs/message_pack.rb
208
+ - lib/magic_pipe/codecs/thrift.rb
209
+ - lib/magic_pipe/codecs/yaml.rb
210
+ - lib/magic_pipe/config.rb
211
+ - lib/magic_pipe/envelope.rb
212
+ - lib/magic_pipe/errors.rb
213
+ - lib/magic_pipe/loaders.rb
214
+ - lib/magic_pipe/loaders/simple_active_record.rb
215
+ - lib/magic_pipe/metrics.rb
216
+ - lib/magic_pipe/senders.rb
217
+ - lib/magic_pipe/senders/async.rb
218
+ - lib/magic_pipe/senders/base.rb
219
+ - lib/magic_pipe/senders/metrics_mixin.rb
220
+ - lib/magic_pipe/senders/sync.rb
221
+ - lib/magic_pipe/transports.rb
222
+ - lib/magic_pipe/transports/base.rb
223
+ - lib/magic_pipe/transports/debug.rb
224
+ - lib/magic_pipe/transports/https.rb
225
+ - lib/magic_pipe/transports/kafka.rb
226
+ - lib/magic_pipe/transports/log.rb
227
+ - lib/magic_pipe/transports/multi.rb
228
+ - lib/magic_pipe/transports/sqs.rb
229
+ - lib/magic_pipe/version.rb
230
+ - magic_pipe.gemspec
231
+ homepage: https://github.com/tompave/magic_pipe
232
+ licenses:
233
+ - MIT
234
+ metadata: {}
235
+ post_install_message:
236
+ rdoc_options: []
237
+ require_paths:
238
+ - lib
239
+ required_ruby_version: !ruby/object:Gem::Requirement
240
+ requirements:
241
+ - - ">="
242
+ - !ruby/object:Gem::Version
243
+ version: '0'
244
+ required_rubygems_version: !ruby/object:Gem::Requirement
245
+ requirements:
246
+ - - ">="
247
+ - !ruby/object:Gem::Version
248
+ version: '0'
249
+ requirements: []
250
+ rubyforge_project:
251
+ rubygems_version: 2.6.14
252
+ signing_key:
253
+ specification_version: 4
254
+ summary: A Magic Pipe to send data in arbitrary formats to configurable backends,
255
+ with topics.
256
+ test_files: []
257
+ has_rdoc: