za.co.absa.pramen.api.Sink.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pramen-api_2.13 Show documentation
Show all versions of pramen-api_2.13 Show documentation
Batch data pipeline management tool
The newest version!
/*
* Copyright 2022 ABSA Group Limited
*
* 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 za.co.absa.pramen.api
import org.apache.spark.sql.{DataFrame, SparkSession}
import java.time.LocalDate
/**
* A sink is an entity where jobs can write to and it won't be under metastore control (e.g. Kafka).
*
* Sink jobs are used to write tables from metastore to a sink.
* Transfer jobs are used to read data from a source and write it to a sink.
*/
trait Sink extends ExternalChannel {
/**
* Sends the given data frame to the sink.
*
* @param df the dataframe containing data to send to the sink (with all transformations and filters applied).
* @param tableName the name of the table from which the data is coming from.
* @param metastore the metastore reader to read other tables from.
* @param infoDate the information date to use when reading the table from the metastore.
* @param options arbitrary extra options to use for the table (e.g. topic name, etc.)
* @return The object containing information about the successful records sent.
*/
def send(df: DataFrame,
tableName: String,
metastore: MetastoreReader,
infoDate: LocalDate,
options: Map[String, String])
(implicit spark: SparkSession): SinkResult
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy