redshift-connector 7.0.0 → 7.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
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 2a4d66a20517246040bb90868247fd86afcf9b2a
|
4
|
+
data.tar.gz: f65cf5432e970b663762c2ef25d8953c01c3a449
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 8d0c198cdf127d1ca1fd13a9552852100f990e5fc6a44f02b0f53e1f31905b03dee9b3d0b377f00cfb497514366f3df2079193015c51b92dc260f391c4c4eee4
|
7
|
+
data.tar.gz: 1da370161d79fde4d8c8b24feb04fcf5bee6fb141e9ba11c08034e0cb3d28afb56c1ab1e9447b7746dca2b42bbdb96637a6dceee6f5d6f5390b09076a613cf24
|
data/lib/redshift_connector.rb
CHANGED
@@ -5,6 +5,7 @@ require 'redshift_connector/connector'
|
|
5
5
|
require 'redshift_connector/exporter'
|
6
6
|
require 'redshift_connector/active_record_data_source'
|
7
7
|
require 'redshift_connector/active_record_exporter'
|
8
|
+
require 'redshift_connector/immediate_exporter'
|
8
9
|
require 'redshift_connector/importer'
|
9
10
|
require 'redshift_connector/s3_bucket'
|
10
11
|
require 'redshift_connector/s3_data_file_bundle'
|
@@ -21,11 +22,11 @@ module RedshiftConnector
|
|
21
22
|
end
|
22
23
|
|
23
24
|
def RedshiftConnector.transport_delta_from_s3(**params)
|
24
|
-
|
25
|
+
Connector.transport_delta_from_s3(**params)
|
25
26
|
end
|
26
27
|
|
27
28
|
def RedshiftConnector.transport_all_from_s3(**params)
|
28
|
-
|
29
|
+
Connector.transport_all_from_s3(**params)
|
29
30
|
end
|
30
31
|
|
31
32
|
def RedshiftConnector.foreach(**params, &block)
|
@@ -1,10 +1,43 @@
|
|
1
1
|
require 'redshift_connector/exporter'
|
2
|
+
require 'redshift_connector/immediate_exporter'
|
2
3
|
require 'redshift_connector/importer'
|
3
4
|
require 'redshift_connector/data_file_bundle_params'
|
5
|
+
require 'redshift_connector/s3_data_file_bundle'
|
4
6
|
require 'redshift_connector/logger'
|
5
7
|
|
6
8
|
module RedshiftConnector
|
7
9
|
class Connector
|
10
|
+
def Connector.transport_delta_from_s3(
|
11
|
+
bucket: nil,
|
12
|
+
prefix:,
|
13
|
+
format:,
|
14
|
+
filter: nil,
|
15
|
+
table:,
|
16
|
+
columns:,
|
17
|
+
delete_cond: nil,
|
18
|
+
upsert_columns: nil,
|
19
|
+
logger: RedshiftConnector.logger,
|
20
|
+
quiet: false
|
21
|
+
)
|
22
|
+
logger = NullLogger.new if quiet
|
23
|
+
bundle = S3DataFileBundle.for_prefix(
|
24
|
+
bucket: (bucket ? S3Bucket.get(bucket) : S3Bucket.default),
|
25
|
+
prefix: prefix,
|
26
|
+
format: format,
|
27
|
+
filter: filter,
|
28
|
+
logger: logger
|
29
|
+
)
|
30
|
+
exporter = ImmediateExporter.new(bundle: bundle, logger: logger)
|
31
|
+
importer = Importer.for_delta_upsert(
|
32
|
+
table: table,
|
33
|
+
columns: columns,
|
34
|
+
delete_cond: delete_cond,
|
35
|
+
upsert_columns: upsert_columns,
|
36
|
+
logger: logger
|
37
|
+
)
|
38
|
+
new(exporter: exporter, importer: importer, logger: logger)
|
39
|
+
end
|
40
|
+
|
8
41
|
def Connector.transport_delta(
|
9
42
|
schema:,
|
10
43
|
table: nil,
|
@@ -50,6 +83,35 @@ module RedshiftConnector
|
|
50
83
|
new(exporter: exporter, importer: importer, logger: logger)
|
51
84
|
end
|
52
85
|
|
86
|
+
def Connector.transport_all_from_s3(
|
87
|
+
strategy: 'rename',
|
88
|
+
table:,
|
89
|
+
columns:,
|
90
|
+
bucket: nil,
|
91
|
+
prefix:,
|
92
|
+
format:,
|
93
|
+
filter: nil,
|
94
|
+
logger: RedshiftConnector.logger,
|
95
|
+
quiet: false
|
96
|
+
)
|
97
|
+
logger = NullLogger.new if quiet
|
98
|
+
bundle = S3DataFileBundle.for_prefix(
|
99
|
+
bucket: (bucket ? S3Bucket.get(bucket) : S3Bucket.default),
|
100
|
+
prefix: prefix,
|
101
|
+
format: format,
|
102
|
+
filter: filter,
|
103
|
+
logger: logger
|
104
|
+
)
|
105
|
+
exporter = ImmediateExporter.new(bundle: bundle, logger: logger)
|
106
|
+
importer = Importer.for_rebuild(
|
107
|
+
strategy: strategy,
|
108
|
+
table: table,
|
109
|
+
columns: columns,
|
110
|
+
logger: logger
|
111
|
+
)
|
112
|
+
new(exporter: exporter, importer: importer, logger: logger)
|
113
|
+
end
|
114
|
+
|
53
115
|
def Connector.transport_all(
|
54
116
|
strategy: 'rename',
|
55
117
|
schema:,
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require 'redshift_connector/s3_data_file_bundle'
|
2
|
+
require 'redshift_connector/logger'
|
3
|
+
|
4
|
+
module RedshiftConnector
|
5
|
+
class ImmediateExporter
|
6
|
+
def initialize(bundle:, logger: RedshiftConnector.logger)
|
7
|
+
@bundle = bundle
|
8
|
+
@logger = logger
|
9
|
+
end
|
10
|
+
|
11
|
+
attr_reader :bundle
|
12
|
+
attr_reader :logger
|
13
|
+
|
14
|
+
def execute
|
15
|
+
@logger.info "USE #{@bundle.url}*"
|
16
|
+
@bundle
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: redshift-connector
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 7.0.
|
4
|
+
version: 7.0.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Minero Aoki
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2017-06-
|
11
|
+
date: 2017-06-20 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: redshift-connector-data_file
|
@@ -152,6 +152,7 @@ files:
|
|
152
152
|
- lib/redshift_connector/exception.rb
|
153
153
|
- lib/redshift_connector/exporter.rb
|
154
154
|
- lib/redshift_connector/exporter_builder.rb
|
155
|
+
- lib/redshift_connector/immediate_exporter.rb
|
155
156
|
- lib/redshift_connector/importer.rb
|
156
157
|
- lib/redshift_connector/importer/activerecord-import.rb
|
157
158
|
- lib/redshift_connector/importer/insert_delta.rb
|