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

io.openlineage.client.transports.kinesis.KinesisConfig Maven / Gradle / Ivy

There is a newer version: 1.26.0
Show newest version
/*
/* Copyright 2018-2024 contributors to the OpenLineage project
/* SPDX-License-Identifier: Apache-2.0
*/

package io.openlineage.client.transports.kinesis;

import com.fasterxml.jackson.annotation.JsonProperty;
import io.openlineage.client.MergeConfig;
import io.openlineage.client.transports.TransportConfig;
import java.util.Properties;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;

@NoArgsConstructor
@AllArgsConstructor
@ToString
public final class KinesisConfig implements TransportConfig, MergeConfig {
  @Getter @Setter private String streamName;
  @Getter @Setter private String region;
  @Getter @Setter private String roleArn;

  // check
  // https://github.com/awslabs/amazon-kinesis-producer/blob/master/java/amazon-kinesis-producer-sample/default_config.properties
  @JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
  @Getter
  @Setter
  private Properties properties;

  @Override
  public KinesisConfig mergeWithNonNull(KinesisConfig other) {
    Properties p = new Properties();
    p.putAll(mergePropertyWith(properties, other.properties));

    return new KinesisConfig(
        mergePropertyWith(streamName, other.streamName),
        mergePropertyWith(region, other.region),
        mergePropertyWith(roleArn, other.roleArn),
        p);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy