Sha256: 1ee873c02f7bfa61b6c7644a5681144ce4790462e78c25732c6510b6dc6a5aa4
Contents?: true
Size: 1.1 KB
Versions: 1
Compression:
Stored size: 1.1 KB
Contents
require 'chronicle/etl' module Chronicle module ETL # Abstract class representing an Extractor for an ETL job class Extractor extend Chronicle::ETL::Catalog # Construct a new instance of this extractor. Options are passed in from a Runner # == Paramters: # options:: # Options for configuring this Extractor def initialize(options = {}) @options = options.transform_keys!(&:to_sym) handle_continuation end # Entrypoint for this Extractor. Called by a Runner. Expects a series of records to be yielded def extract raise NotImplementedError end # An optional method to calculate how many records there are to extract. Used primarily for # building the progress bar def results_count; end private def handle_continuation @options[:load_since] = @options[:continuation].highest_timestamp if @options[:continuation] && @options[:continuation].highest_timestamp end end end end require_relative 'csv_extractor' require_relative 'file_extractor' require_relative 'stdin_extractor'
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
chronicle-etl-0.2.3 | lib/chronicle/etl/extractors/extractor.rb |