io.github.cdklabs.cdk.appflow.RedshiftDestinationProps Maven / Gradle / Ivy
package io.github.cdklabs.cdk.appflow;
/**
*/
@javax.annotation.Generated(value = "jsii-pacmak/1.103.1 (build bef2dea)", date = "2024-09-23T07:35:38.267Z")
@software.amazon.jsii.Jsii(module = io.github.cdklabs.cdk.appflow.$Module.class, fqn = "@cdklabs/cdk-appflow.RedshiftDestinationProps")
@software.amazon.jsii.Jsii.Proxy(RedshiftDestinationProps.Jsii$Proxy.class)
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
public interface RedshiftDestinationProps extends software.amazon.jsii.JsiiSerializable {
/**
* (experimental) A Redshift table object (optionally with the schema).
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
@org.jetbrains.annotations.NotNull io.github.cdklabs.cdk.appflow.RedshiftDestinationObject getObject();
/**
* (experimental) An instance of the.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
@org.jetbrains.annotations.NotNull io.github.cdklabs.cdk.appflow.RedshiftConnectorProfile getProfile();
/**
* (experimental) The settings that determine how Amazon AppFlow handles an error when placing data in the Salesforce destination.
*
* For example, this setting would determine if the flow should fail after one insertion error, or continue and attempt to insert every record regardless of the initial failure.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
default @org.jetbrains.annotations.Nullable io.github.cdklabs.cdk.appflow.ErrorHandlingConfiguration getErrorHandling() {
return null;
}
/**
* @return a {@link Builder} of {@link RedshiftDestinationProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
static Builder builder() {
return new Builder();
}
/**
* A builder for {@link RedshiftDestinationProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
public static final class Builder implements software.amazon.jsii.Builder {
io.github.cdklabs.cdk.appflow.RedshiftDestinationObject object;
io.github.cdklabs.cdk.appflow.RedshiftConnectorProfile profile;
io.github.cdklabs.cdk.appflow.ErrorHandlingConfiguration errorHandling;
/**
* Sets the value of {@link RedshiftDestinationProps#getObject}
* @param object A Redshift table object (optionally with the schema). This parameter is required.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
public Builder object(io.github.cdklabs.cdk.appflow.RedshiftDestinationObject object) {
this.object = object;
return this;
}
/**
* Sets the value of {@link RedshiftDestinationProps#getProfile}
* @param profile An instance of the. This parameter is required.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
public Builder profile(io.github.cdklabs.cdk.appflow.RedshiftConnectorProfile profile) {
this.profile = profile;
return this;
}
/**
* Sets the value of {@link RedshiftDestinationProps#getErrorHandling}
* @param errorHandling The settings that determine how Amazon AppFlow handles an error when placing data in the Salesforce destination.
* For example, this setting would determine if the flow should fail after one insertion error, or continue and attempt to insert every record regardless of the initial failure.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
public Builder errorHandling(io.github.cdklabs.cdk.appflow.ErrorHandlingConfiguration errorHandling) {
this.errorHandling = errorHandling;
return this;
}
/**
* Builds the configured instance.
* @return a new instance of {@link RedshiftDestinationProps}
* @throws NullPointerException if any required attribute was not provided
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
@Override
public RedshiftDestinationProps build() {
return new Jsii$Proxy(this);
}
}
/**
* An implementation for {@link RedshiftDestinationProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
@software.amazon.jsii.Internal
final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements RedshiftDestinationProps {
private final io.github.cdklabs.cdk.appflow.RedshiftDestinationObject object;
private final io.github.cdklabs.cdk.appflow.RedshiftConnectorProfile profile;
private final io.github.cdklabs.cdk.appflow.ErrorHandlingConfiguration errorHandling;
/**
* Constructor that initializes the object based on values retrieved from the JsiiObject.
* @param objRef Reference to the JSII managed object.
*/
protected Jsii$Proxy(final software.amazon.jsii.JsiiObjectRef objRef) {
super(objRef);
this.object = software.amazon.jsii.Kernel.get(this, "object", software.amazon.jsii.NativeType.forClass(io.github.cdklabs.cdk.appflow.RedshiftDestinationObject.class));
this.profile = software.amazon.jsii.Kernel.get(this, "profile", software.amazon.jsii.NativeType.forClass(io.github.cdklabs.cdk.appflow.RedshiftConnectorProfile.class));
this.errorHandling = software.amazon.jsii.Kernel.get(this, "errorHandling", software.amazon.jsii.NativeType.forClass(io.github.cdklabs.cdk.appflow.ErrorHandlingConfiguration.class));
}
/**
* Constructor that initializes the object based on literal property values passed by the {@link Builder}.
*/
protected Jsii$Proxy(final Builder builder) {
super(software.amazon.jsii.JsiiObject.InitializationMode.JSII);
this.object = java.util.Objects.requireNonNull(builder.object, "object is required");
this.profile = java.util.Objects.requireNonNull(builder.profile, "profile is required");
this.errorHandling = builder.errorHandling;
}
@Override
public final io.github.cdklabs.cdk.appflow.RedshiftDestinationObject getObject() {
return this.object;
}
@Override
public final io.github.cdklabs.cdk.appflow.RedshiftConnectorProfile getProfile() {
return this.profile;
}
@Override
public final io.github.cdklabs.cdk.appflow.ErrorHandlingConfiguration getErrorHandling() {
return this.errorHandling;
}
@Override
@software.amazon.jsii.Internal
public com.fasterxml.jackson.databind.JsonNode $jsii$toJson() {
final com.fasterxml.jackson.databind.ObjectMapper om = software.amazon.jsii.JsiiObjectMapper.INSTANCE;
final com.fasterxml.jackson.databind.node.ObjectNode data = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
data.set("object", om.valueToTree(this.getObject()));
data.set("profile", om.valueToTree(this.getProfile()));
if (this.getErrorHandling() != null) {
data.set("errorHandling", om.valueToTree(this.getErrorHandling()));
}
final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
struct.set("fqn", om.valueToTree("@cdklabs/cdk-appflow.RedshiftDestinationProps"));
struct.set("data", data);
final com.fasterxml.jackson.databind.node.ObjectNode obj = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
obj.set("$jsii.struct", struct);
return obj;
}
@Override
public final boolean equals(final Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
RedshiftDestinationProps.Jsii$Proxy that = (RedshiftDestinationProps.Jsii$Proxy) o;
if (!object.equals(that.object)) return false;
if (!profile.equals(that.profile)) return false;
return this.errorHandling != null ? this.errorHandling.equals(that.errorHandling) : that.errorHandling == null;
}
@Override
public final int hashCode() {
int result = this.object.hashCode();
result = 31 * result + (this.profile.hashCode());
result = 31 * result + (this.errorHandling != null ? this.errorHandling.hashCode() : 0);
return result;
}
}
}