All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.streamsets.pipeline.api.Source Maven / Gradle / Ivy

The newest version!
/*
 * Copyright contributors to the StreamSets project
 * StreamSets Inc., an IBM Company 2024
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.streamsets.pipeline.api;

/**
 * A Source is Data Collector origin stage. Origin stages consume data from an external system
 * creating records that can be processed by processor ({@link Processor}) or destination ({@link Target}) stages.
 *
 * @see Processor
 * @see Target
 */
public interface Source extends ProtoSource {

  /**
   * Data collector is using a Map to keep track of offsets. As this Source uses only one
   * dimensional String instead, the offset is kept in the map with given key. This constant is particularly
   * useful when you switched source from Source to PushSource and you need to get back the Source's version of
   * the offset.
   */
  public static final String POLL_SOURCE_OFFSET_KEY = "$com.streamsets.datacollector.pollsource.offset$";

  /**
   * Source stage context.
   */
  public interface Context extends ProtoSource.Context, ToErrorContext, ToEventContext, ProcessedContext {
  }

  /**
   * When running a pipeline, the Data Collector calls this method from the Source stage to obtain a batch
   * of records for processing.
   * 

* Source stages should not block indefinitely within this method if there is no data. They should have * an internal timeout after which they produce an empty batch. By doing so it gives the chance to other stages in * pipeline to know that the pipeline is still healthy but there is no data coming; and potentially allowing * notifications to external systems. * * @param lastSourceOffset the offset returned by the previous call to this method, or NULL if this * method is being called for the first time ever. * @param maxBatchSize the requested maximum batch size a single call to this method should produce. * @param batchMaker records created by the Source stage must be added to the BatchMaker * for them to be available to the rest of the pipeline. * @return the offset for the next call to this method. If NULL is returned it means the * Source stage has fully process that data, that no more data is to be expected and that the * pipeline should finish once the current batch is fully processed. * @throws StageException if the Source had an error while consuming data or creating records. */ public String produce(String lastSourceOffset, int maxBatchSize, BatchMaker batchMaker) throws StageException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy