Sha256: 3c1598a8b2a83ccc09b62675a52a0e3dd06ae0e0d4200c5efa53ebb5adf7a143

Contents?: true

Size: 1.58 KB

Versions: 4

Compression:

Stored size: 1.58 KB

Contents

require_relative 'helpers/encoding_helper'
require_relative 'helpers/stdout_helper'

module Chronicle
  module ETL
    # Abstract class representing a Loader for an ETL job
    class Loader
      extend Chronicle::ETL::Registry::SelfRegistering
      include Chronicle::ETL::Configurable
      include Chronicle::ETL::Loaders::Helpers::EncodingHelper

      setting :output
      setting :fields
      setting :fields_limit, default: nil
      setting :fields_exclude

      # Construct a new instance of this loader. Options are passed in from a Runner
      # == Parameters:
      # options::
      #   Options for configuring this Loader
      def initialize(options = {})
        apply_options(options)
      end

      # Called once before processing records
      def start; end

      # Load a single record
      def load
        raise NotImplementedError
      end

      # Called once there are no more records to process
      def finish; end

      private

      def build_headers(records)
        headers =
          if @config.fields && @config.fields.any?
            Set[*@config.fields]
          else
            # use all the keys of the flattened record hash
            Set[*records.map(&:keys).flatten.map(&:to_s).uniq]
          end

        headers = headers.delete_if { |header| header.end_with?(*@config.fields_exclude) }
        headers = headers.first(@config.fields_limit) if @config.fields_limit

        headers.to_a.map(&:to_sym)
      end
    end
  end
end

require_relative 'csv_loader'
require_relative 'json_loader'
require_relative 'rest_loader'
require_relative 'table_loader'

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
chronicle-etl-0.5.5 lib/chronicle/etl/loaders/loader.rb
chronicle-etl-0.5.4 lib/chronicle/etl/loaders/loader.rb
chronicle-etl-0.5.3 lib/chronicle/etl/loaders/loader.rb
chronicle-etl-0.5.2 lib/chronicle/etl/loaders/loader.rb