aktivlearn_stream 0.0.71 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/aktivlearn_stream.rb +20 -3
- data/lib/config.rb +4 -8
- data/lib/stream.rb +3 -21
- metadata +2 -17
- data/lib/stream_config.yml +0 -5
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: eb84e6155f06e4c12e8a5aead3e37cff8c4ceb64ef546b5af83f42c612ac2bb6
|
4
|
+
data.tar.gz: 7cca84ba98cce61dd75b826ac2d22f35135c15be39bead7bb4660c61cb7c1040
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ff63e192cd63462661c17939e3d552b5e773ea18084de69adfa4ac72a24b2bab92212b41a640e8029f89c4e4995934608e3fc0c3c1b8d9c0600310c4978940bb
|
7
|
+
data.tar.gz: e9420ffc797dca5e8f62a93a9a41081d40bac79eb18966e64b9cc18b0c0f982d0f4a6ce39be211877120f37e914c45d7ad81f35dccabbaf098c6fbf2fa0febd1
|
data/lib/aktivlearn_stream.rb
CHANGED
@@ -2,11 +2,28 @@ require 'config'
|
|
2
2
|
require 'stream'
|
3
3
|
module AktivlearnStream
|
4
4
|
|
5
|
-
|
5
|
+
def self.read_config config
|
6
|
+
@config = config
|
7
|
+
AktivlearnStream::Config.validate_config(@config)
|
8
|
+
set_connection
|
9
|
+
end
|
10
|
+
|
11
|
+
|
12
|
+
def self.set_connection
|
13
|
+
@config ||= {}
|
14
|
+
begin
|
15
|
+
@firehose = Aws::Firehose::Client.new(
|
16
|
+
access_key_id: @config["service_key"],
|
17
|
+
secret_access_key: @config["service_secret"],
|
18
|
+
region: @config["region"]
|
19
|
+
)
|
20
|
+
rescue Exception => e
|
21
|
+
raise (StandardError.new("Could not establish a connection. Check the config. Error message === #{e.message}"))
|
22
|
+
end
|
23
|
+
end
|
6
24
|
|
7
25
|
def self.send(raw_data)
|
8
|
-
AktivlearnStream::
|
9
|
-
AktivlearnStream::Stream.send_stream(@config,raw_data)
|
26
|
+
AktivlearnStream::Stream.send_raw_data(@config,@firehose,raw_data)
|
10
27
|
end
|
11
28
|
|
12
29
|
end
|
data/lib/config.rb
CHANGED
@@ -1,15 +1,11 @@
|
|
1
1
|
module AktivlearnStream
|
2
2
|
class Config
|
3
|
-
|
4
|
-
require 'rails'
|
5
|
-
def self.read_config
|
6
|
-
@config = YAML.load_file(Rails.root + 'config/stream_config.yml') rescue nil
|
7
|
-
end
|
8
|
-
|
3
|
+
|
9
4
|
ALLOWED_SERVICE_TYPES = ["azure","aws"]
|
10
|
-
|
11
|
-
def self.validate_config
|
5
|
+
|
6
|
+
def self.validate_config(config)
|
12
7
|
begin
|
8
|
+
@config = config || {}
|
13
9
|
@config["type_of_service"] || raise(StandardError.new('Specify the servcie type'))
|
14
10
|
@config["service_key"] || raise(StandardError.new('Service Key is missing, please specify in config'))
|
15
11
|
@config["service_secret"] || raise(StandardError.new('Service Secret is missing, please specify in config'))
|
data/lib/stream.rb
CHANGED
@@ -1,28 +1,10 @@
|
|
1
|
-
module
|
1
|
+
module AktivlearnStream
|
2
2
|
class Stream
|
3
3
|
|
4
|
-
def self.
|
5
|
-
set_connection(config)
|
6
|
-
send_raw_data(raw_data)
|
7
|
-
end
|
8
|
-
|
9
|
-
def self.set_connection(config)
|
10
|
-
@config = config || {}
|
4
|
+
def self.send_raw_data(config,firehose,raw_data)
|
11
5
|
begin
|
12
|
-
|
13
|
-
access_key_id: @config["service_key"],
|
14
|
-
secret_access_key: @config["service_secret"],
|
15
|
-
region: @config["region"]
|
16
|
-
)
|
6
|
+
firehose.put_record({ delivery_stream_name: config["delivery_stream_name"], record: { data: raw_data}})
|
17
7
|
rescue Exception => e
|
18
|
-
raise (StandardError.new("Could not establish a connection. Check the config. Error message === #{e.message}"))
|
19
|
-
end
|
20
|
-
end
|
21
|
-
|
22
|
-
def self.send_raw_data(raw_data)
|
23
|
-
begin
|
24
|
-
@firehose.put_record({ delivery_stream_name: @config["delivery_stream_name"], record: { data: raw_data}})
|
25
|
-
rescue Aws::Errors::MissingCredentialsError => e
|
26
8
|
raise (StandardError.new("Error with the connection. Check the config. Error message === #{e.message}"))
|
27
9
|
end
|
28
10
|
end
|
metadata
CHANGED
@@ -1,29 +1,15 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: aktivlearn_stream
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0
|
4
|
+
version: 0.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Saran
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2018-08-
|
11
|
+
date: 2018-08-09 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
|
-
- !ruby/object:Gem::Dependency
|
14
|
-
name: rails
|
15
|
-
requirement: !ruby/object:Gem::Requirement
|
16
|
-
requirements:
|
17
|
-
- - '='
|
18
|
-
- !ruby/object:Gem::Version
|
19
|
-
version: 4.0.13
|
20
|
-
type: :runtime
|
21
|
-
prerelease: false
|
22
|
-
version_requirements: !ruby/object:Gem::Requirement
|
23
|
-
requirements:
|
24
|
-
- - '='
|
25
|
-
- !ruby/object:Gem::Version
|
26
|
-
version: 4.0.13
|
27
13
|
- !ruby/object:Gem::Dependency
|
28
14
|
name: aws-sdk
|
29
15
|
requirement: !ruby/object:Gem::Requirement
|
@@ -53,7 +39,6 @@ files:
|
|
53
39
|
- lib/aktivlearn_stream.rb
|
54
40
|
- lib/config.rb
|
55
41
|
- lib/stream.rb
|
56
|
-
- lib/stream_config.yml
|
57
42
|
homepage: ''
|
58
43
|
licenses:
|
59
44
|
- Nonstandard
|