Module: RedshiftConnector::Importer

Defined in:
lib/redshift-connector/importer.rb,
lib/redshift-connector/importer.rb

Defined Under Namespace

Classes: InsertDelta, RebuildRename, RebuildTruncate, Upsert

Class Method Summary collapse

Class Method Details

.get_rebuild_class(strategy) ⇒ Object



80
81
82
83
84
85
86
87
# File 'lib/redshift-connector/importer.rb', line 80

def Importer.get_rebuild_class(strategy)
  case strategy.to_s
  when 'rename' then RebuildRename
  when 'truncate' then RebuildTruncate
  else
    raise ArgumentError, "unsupported rebuild strategy: #{strategy.inspect}"
  end
end

.transport_all_from_s3(strategy: 'rename', bucket: nil, prefix:, format:, filter: nil, table:, columns:, logger: RedshiftConnector.logger, quiet: false) ⇒ Object



57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# File 'lib/redshift-connector/importer.rb', line 57

def Importer.transport_all_from_s3(
    strategy: 'rename',
    bucket: nil, prefix:, format:, filter: nil,
    table:, columns:,
    logger: RedshiftConnector.logger, quiet: false)
  bucket = bucket ? S3Bucket.get(bucket) : S3Bucket.default
  logger = NullLogger.new if quiet
  bundle = S3DataFileBundle.for_prefix(
    bucket: bucket,
    prefix: prefix,
    format: format,
    filter: filter,
    logger: logger
  )
  importer = get_rebuild_class(strategy).new(
    dao: table.classify.constantize,
    bundle: bundle,
    columns: columns,
    logger: logger
  )
  importer
end

.transport_delta_from_s3(bucket: nil, prefix:, format:, filter: nil, table:, columns:, delete_cond: nil, upsert_columns: nil, logger: RedshiftConnector.logger, quiet: false) ⇒ Object



17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# File 'lib/redshift-connector/importer.rb', line 17

def Importer.transport_delta_from_s3(
    bucket: nil, prefix:, format:, filter: nil,
    table:, columns:,
    delete_cond: nil, upsert_columns: nil,
    logger: RedshiftConnector.logger, quiet: false)
  bucket = bucket ? S3Bucket.get(bucket) : S3Bucket.default
  logger = NullLogger.new if quiet
  bundle = S3DataFileBundle.for_prefix(
    bucket: bucket,
    prefix: prefix,
    format: format,
    filter: filter,
    logger: logger
  )
  if delete_cond and upsert_columns
    raise ArgumentError, "delete_cond and upsert_columns are exclusive"
  end
  importer =
    if delete_cond
      Importer::InsertDelta.new(
        dao: table.classify.constantize,
        bundle: bundle,
        columns: columns,
        delete_cond: delete_cond,
        logger: logger
      )
    elsif upsert_columns
      Importer::Upsert.new(
        dao: table.classify.constantize,
        bundle: bundle,
        columns: columns,
        upsert_columns: upsert_columns,
        logger: logger
      )
    else
      raise ArgumentError, "either of delete_cond or upsert_columns is required for transport_delta"
    end
  importer
end