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

org.openmetadata.schema.services.connections.database.ImpalaConnection Maven / Gradle / Ivy

There is a newer version: 1.6.0-rc1
Show newest version

package org.openmetadata.schema.services.connections.database;

import java.util.HashMap;
import java.util.Map;
import javax.annotation.processing.Generated;
import javax.validation.Valid;
import javax.validation.constraints.NotNull;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyDescription;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.fasterxml.jackson.annotation.JsonValue;
import org.openmetadata.annotations.PasswordField;


/**
 * ImpalaConnection
 * 

* Impala SQL Connection Config * */ @JsonInclude(JsonInclude.Include.NON_NULL) @JsonPropertyOrder({ "type", "scheme", "username", "password", "hostPort", "authMechanism", "kerberosServiceName", "databaseSchema", "databaseName", "useSSL", "authOptions", "connectionOptions", "connectionArguments", "supportsMetadataExtraction", "supportsDBTExtraction", "supportsProfiler", "sampleDataStorageConfig", "supportsViewLineageExtraction" }) @Generated("jsonschema2pojo") public class ImpalaConnection { /** * Service type. * */ @JsonProperty("type") @JsonPropertyDescription("Service type.") private ImpalaConnection.ImpalaType type = ImpalaConnection.ImpalaType.fromValue("Impala"); /** * SQLAlchemy driver scheme options. * */ @JsonProperty("scheme") @JsonPropertyDescription("SQLAlchemy driver scheme options.") private ImpalaConnection.ImpalaScheme scheme = ImpalaConnection.ImpalaScheme.fromValue("impala"); /** * Username *

* Username to connect to Impala. This user should have privileges to read all the metadata in Impala. * */ @JsonProperty("username") @JsonPropertyDescription("Username to connect to Impala. This user should have privileges to read all the metadata in Impala.") private String username; /** * Password *

* Password to connect to Impala. * */ @JsonProperty("password") @JsonPropertyDescription("Password to connect to Impala.") @PasswordField private String password; /** * Host and Port *

* Host and port of the Impala service. * (Required) * */ @JsonProperty("hostPort") @JsonPropertyDescription("Host and port of the Impala service.") @NotNull private String hostPort; /** * Authentication Mode *

* Authentication mode to connect to Impala. * */ @JsonProperty("authMechanism") @JsonPropertyDescription("Authentication mode to connect to Impala.") private ImpalaConnection.AuthMechanism authMechanism = ImpalaConnection.AuthMechanism.fromValue("PLAIN"); /** * Kerberos Service Name *

* If authenticating with Kerberos specify the Kerberos service name * */ @JsonProperty("kerberosServiceName") @JsonPropertyDescription("If authenticating with Kerberos specify the Kerberos service name") private String kerberosServiceName; /** * Database Schema *

* Database Schema of the data source. This is optional parameter, if you would like to restrict the metadata reading to a single schema. When left blank, OpenMetadata Ingestion attempts to scan all the schemas. * */ @JsonProperty("databaseSchema") @JsonPropertyDescription("Database Schema of the data source. This is optional parameter, if you would like to restrict the metadata reading to a single schema. When left blank, OpenMetadata Ingestion attempts to scan all the schemas.") private String databaseSchema; /** * Database Name *

* Optional name to give to the database in OpenMetadata. If left blank, we will use default as the database name. * */ @JsonProperty("databaseName") @JsonPropertyDescription("Optional name to give to the database in OpenMetadata. If left blank, we will use default as the database name.") private String databaseName; /** * Use SSL *

* Establish secure connection with Impala * */ @JsonProperty("useSSL") @JsonPropertyDescription("Establish secure connection with Impala") private Boolean useSSL; /** * URL Authentication Options *

* Authentication options to pass to Impala connector. These options are based on SQLAlchemy. * */ @JsonProperty("authOptions") @JsonPropertyDescription("Authentication options to pass to Impala connector. These options are based on SQLAlchemy.") private String authOptions; /** * Additional connection options to build the URL that can be sent to service during the connection. * */ @JsonProperty("connectionOptions") @JsonPropertyDescription("Additional connection options to build the URL that can be sent to service during the connection.") @Valid private ConnectionOptions connectionOptions; /** * Additional connection arguments such as security or protocol configs that can be sent to service during connection. * */ @JsonProperty("connectionArguments") @JsonPropertyDescription("Additional connection arguments such as security or protocol configs that can be sent to service during connection.") @Valid private ConnectionArguments connectionArguments; /** * Supports Metadata Extraction. * */ @JsonProperty("supportsMetadataExtraction") @JsonPropertyDescription("Supports Metadata Extraction.") private Boolean supportsMetadataExtraction = true; /** * Supports DBT Extraction. * */ @JsonProperty("supportsDBTExtraction") @JsonPropertyDescription("Supports DBT Extraction.") private Boolean supportsDBTExtraction = true; /** * Supports Profiler * */ @JsonProperty("supportsProfiler") @JsonPropertyDescription("Supports Profiler") private Boolean supportsProfiler = true; /** * Storage config to store sample data * */ @JsonProperty("sampleDataStorageConfig") @JsonPropertyDescription("Storage config to store sample data") @Valid private SampleDataStorageConfig sampleDataStorageConfig; /** * Supports View Lineage Extraction. * */ @JsonProperty("supportsViewLineageExtraction") @JsonPropertyDescription("Supports View Lineage Extraction.") private Boolean supportsViewLineageExtraction = true; /** * Service type. * */ @JsonProperty("type") public ImpalaConnection.ImpalaType getType() { return type; } /** * Service type. * */ @JsonProperty("type") public void setType(ImpalaConnection.ImpalaType type) { this.type = type; } public ImpalaConnection withType(ImpalaConnection.ImpalaType type) { this.type = type; return this; } /** * SQLAlchemy driver scheme options. * */ @JsonProperty("scheme") public ImpalaConnection.ImpalaScheme getScheme() { return scheme; } /** * SQLAlchemy driver scheme options. * */ @JsonProperty("scheme") public void setScheme(ImpalaConnection.ImpalaScheme scheme) { this.scheme = scheme; } public ImpalaConnection withScheme(ImpalaConnection.ImpalaScheme scheme) { this.scheme = scheme; return this; } /** * Username *

* Username to connect to Impala. This user should have privileges to read all the metadata in Impala. * */ @JsonProperty("username") public String getUsername() { return username; } /** * Username *

* Username to connect to Impala. This user should have privileges to read all the metadata in Impala. * */ @JsonProperty("username") public void setUsername(String username) { this.username = username; } public ImpalaConnection withUsername(String username) { this.username = username; return this; } /** * Password *

* Password to connect to Impala. * */ @JsonProperty("password") @PasswordField public String getPassword() { return password; } /** * Password *

* Password to connect to Impala. * */ @JsonProperty("password") @PasswordField public void setPassword(String password) { this.password = password; } public ImpalaConnection withPassword(String password) { this.password = password; return this; } /** * Host and Port *

* Host and port of the Impala service. * (Required) * */ @JsonProperty("hostPort") public String getHostPort() { return hostPort; } /** * Host and Port *

* Host and port of the Impala service. * (Required) * */ @JsonProperty("hostPort") public void setHostPort(String hostPort) { this.hostPort = hostPort; } public ImpalaConnection withHostPort(String hostPort) { this.hostPort = hostPort; return this; } /** * Authentication Mode *

* Authentication mode to connect to Impala. * */ @JsonProperty("authMechanism") public ImpalaConnection.AuthMechanism getAuthMechanism() { return authMechanism; } /** * Authentication Mode *

* Authentication mode to connect to Impala. * */ @JsonProperty("authMechanism") public void setAuthMechanism(ImpalaConnection.AuthMechanism authMechanism) { this.authMechanism = authMechanism; } public ImpalaConnection withAuthMechanism(ImpalaConnection.AuthMechanism authMechanism) { this.authMechanism = authMechanism; return this; } /** * Kerberos Service Name *

* If authenticating with Kerberos specify the Kerberos service name * */ @JsonProperty("kerberosServiceName") public String getKerberosServiceName() { return kerberosServiceName; } /** * Kerberos Service Name *

* If authenticating with Kerberos specify the Kerberos service name * */ @JsonProperty("kerberosServiceName") public void setKerberosServiceName(String kerberosServiceName) { this.kerberosServiceName = kerberosServiceName; } public ImpalaConnection withKerberosServiceName(String kerberosServiceName) { this.kerberosServiceName = kerberosServiceName; return this; } /** * Database Schema *

* Database Schema of the data source. This is optional parameter, if you would like to restrict the metadata reading to a single schema. When left blank, OpenMetadata Ingestion attempts to scan all the schemas. * */ @JsonProperty("databaseSchema") public String getDatabaseSchema() { return databaseSchema; } /** * Database Schema *

* Database Schema of the data source. This is optional parameter, if you would like to restrict the metadata reading to a single schema. When left blank, OpenMetadata Ingestion attempts to scan all the schemas. * */ @JsonProperty("databaseSchema") public void setDatabaseSchema(String databaseSchema) { this.databaseSchema = databaseSchema; } public ImpalaConnection withDatabaseSchema(String databaseSchema) { this.databaseSchema = databaseSchema; return this; } /** * Database Name *

* Optional name to give to the database in OpenMetadata. If left blank, we will use default as the database name. * */ @JsonProperty("databaseName") public String getDatabaseName() { return databaseName; } /** * Database Name *

* Optional name to give to the database in OpenMetadata. If left blank, we will use default as the database name. * */ @JsonProperty("databaseName") public void setDatabaseName(String databaseName) { this.databaseName = databaseName; } public ImpalaConnection withDatabaseName(String databaseName) { this.databaseName = databaseName; return this; } /** * Use SSL *

* Establish secure connection with Impala * */ @JsonProperty("useSSL") public Boolean getUseSSL() { return useSSL; } /** * Use SSL *

* Establish secure connection with Impala * */ @JsonProperty("useSSL") public void setUseSSL(Boolean useSSL) { this.useSSL = useSSL; } public ImpalaConnection withUseSSL(Boolean useSSL) { this.useSSL = useSSL; return this; } /** * URL Authentication Options *

* Authentication options to pass to Impala connector. These options are based on SQLAlchemy. * */ @JsonProperty("authOptions") public String getAuthOptions() { return authOptions; } /** * URL Authentication Options *

* Authentication options to pass to Impala connector. These options are based on SQLAlchemy. * */ @JsonProperty("authOptions") public void setAuthOptions(String authOptions) { this.authOptions = authOptions; } public ImpalaConnection withAuthOptions(String authOptions) { this.authOptions = authOptions; return this; } /** * Additional connection options to build the URL that can be sent to service during the connection. * */ @JsonProperty("connectionOptions") public ConnectionOptions getConnectionOptions() { return connectionOptions; } /** * Additional connection options to build the URL that can be sent to service during the connection. * */ @JsonProperty("connectionOptions") public void setConnectionOptions(ConnectionOptions connectionOptions) { this.connectionOptions = connectionOptions; } public ImpalaConnection withConnectionOptions(ConnectionOptions connectionOptions) { this.connectionOptions = connectionOptions; return this; } /** * Additional connection arguments such as security or protocol configs that can be sent to service during connection. * */ @JsonProperty("connectionArguments") public ConnectionArguments getConnectionArguments() { return connectionArguments; } /** * Additional connection arguments such as security or protocol configs that can be sent to service during connection. * */ @JsonProperty("connectionArguments") public void setConnectionArguments(ConnectionArguments connectionArguments) { this.connectionArguments = connectionArguments; } public ImpalaConnection withConnectionArguments(ConnectionArguments connectionArguments) { this.connectionArguments = connectionArguments; return this; } /** * Supports Metadata Extraction. * */ @JsonProperty("supportsMetadataExtraction") public Boolean getSupportsMetadataExtraction() { return supportsMetadataExtraction; } /** * Supports Metadata Extraction. * */ @JsonProperty("supportsMetadataExtraction") public void setSupportsMetadataExtraction(Boolean supportsMetadataExtraction) { this.supportsMetadataExtraction = supportsMetadataExtraction; } public ImpalaConnection withSupportsMetadataExtraction(Boolean supportsMetadataExtraction) { this.supportsMetadataExtraction = supportsMetadataExtraction; return this; } /** * Supports DBT Extraction. * */ @JsonProperty("supportsDBTExtraction") public Boolean getSupportsDBTExtraction() { return supportsDBTExtraction; } /** * Supports DBT Extraction. * */ @JsonProperty("supportsDBTExtraction") public void setSupportsDBTExtraction(Boolean supportsDBTExtraction) { this.supportsDBTExtraction = supportsDBTExtraction; } public ImpalaConnection withSupportsDBTExtraction(Boolean supportsDBTExtraction) { this.supportsDBTExtraction = supportsDBTExtraction; return this; } /** * Supports Profiler * */ @JsonProperty("supportsProfiler") public Boolean getSupportsProfiler() { return supportsProfiler; } /** * Supports Profiler * */ @JsonProperty("supportsProfiler") public void setSupportsProfiler(Boolean supportsProfiler) { this.supportsProfiler = supportsProfiler; } public ImpalaConnection withSupportsProfiler(Boolean supportsProfiler) { this.supportsProfiler = supportsProfiler; return this; } /** * Storage config to store sample data * */ @JsonProperty("sampleDataStorageConfig") public SampleDataStorageConfig getSampleDataStorageConfig() { return sampleDataStorageConfig; } /** * Storage config to store sample data * */ @JsonProperty("sampleDataStorageConfig") public void setSampleDataStorageConfig(SampleDataStorageConfig sampleDataStorageConfig) { this.sampleDataStorageConfig = sampleDataStorageConfig; } public ImpalaConnection withSampleDataStorageConfig(SampleDataStorageConfig sampleDataStorageConfig) { this.sampleDataStorageConfig = sampleDataStorageConfig; return this; } /** * Supports View Lineage Extraction. * */ @JsonProperty("supportsViewLineageExtraction") public Boolean getSupportsViewLineageExtraction() { return supportsViewLineageExtraction; } /** * Supports View Lineage Extraction. * */ @JsonProperty("supportsViewLineageExtraction") public void setSupportsViewLineageExtraction(Boolean supportsViewLineageExtraction) { this.supportsViewLineageExtraction = supportsViewLineageExtraction; } public ImpalaConnection withSupportsViewLineageExtraction(Boolean supportsViewLineageExtraction) { this.supportsViewLineageExtraction = supportsViewLineageExtraction; return this; } @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append(ImpalaConnection.class.getName()).append('@').append(Integer.toHexString(System.identityHashCode(this))).append('['); sb.append("type"); sb.append('='); sb.append(((this.type == null)?"":this.type)); sb.append(','); sb.append("scheme"); sb.append('='); sb.append(((this.scheme == null)?"":this.scheme)); sb.append(','); sb.append("username"); sb.append('='); sb.append(((this.username == null)?"":this.username)); sb.append(','); sb.append("password"); sb.append('='); sb.append(((this.password == null)?"":this.password)); sb.append(','); sb.append("hostPort"); sb.append('='); sb.append(((this.hostPort == null)?"":this.hostPort)); sb.append(','); sb.append("authMechanism"); sb.append('='); sb.append(((this.authMechanism == null)?"":this.authMechanism)); sb.append(','); sb.append("kerberosServiceName"); sb.append('='); sb.append(((this.kerberosServiceName == null)?"":this.kerberosServiceName)); sb.append(','); sb.append("databaseSchema"); sb.append('='); sb.append(((this.databaseSchema == null)?"":this.databaseSchema)); sb.append(','); sb.append("databaseName"); sb.append('='); sb.append(((this.databaseName == null)?"":this.databaseName)); sb.append(','); sb.append("useSSL"); sb.append('='); sb.append(((this.useSSL == null)?"":this.useSSL)); sb.append(','); sb.append("authOptions"); sb.append('='); sb.append(((this.authOptions == null)?"":this.authOptions)); sb.append(','); sb.append("connectionOptions"); sb.append('='); sb.append(((this.connectionOptions == null)?"":this.connectionOptions)); sb.append(','); sb.append("connectionArguments"); sb.append('='); sb.append(((this.connectionArguments == null)?"":this.connectionArguments)); sb.append(','); sb.append("supportsMetadataExtraction"); sb.append('='); sb.append(((this.supportsMetadataExtraction == null)?"":this.supportsMetadataExtraction)); sb.append(','); sb.append("supportsDBTExtraction"); sb.append('='); sb.append(((this.supportsDBTExtraction == null)?"":this.supportsDBTExtraction)); sb.append(','); sb.append("supportsProfiler"); sb.append('='); sb.append(((this.supportsProfiler == null)?"":this.supportsProfiler)); sb.append(','); sb.append("sampleDataStorageConfig"); sb.append('='); sb.append(((this.sampleDataStorageConfig == null)?"":this.sampleDataStorageConfig)); sb.append(','); sb.append("supportsViewLineageExtraction"); sb.append('='); sb.append(((this.supportsViewLineageExtraction == null)?"":this.supportsViewLineageExtraction)); sb.append(','); if (sb.charAt((sb.length()- 1)) == ',') { sb.setCharAt((sb.length()- 1), ']'); } else { sb.append(']'); } return sb.toString(); } @Override public int hashCode() { int result = 1; result = ((result* 31)+((this.databaseSchema == null)? 0 :this.databaseSchema.hashCode())); result = ((result* 31)+((this.supportsMetadataExtraction == null)? 0 :this.supportsMetadataExtraction.hashCode())); result = ((result* 31)+((this.authOptions == null)? 0 :this.authOptions.hashCode())); result = ((result* 31)+((this.scheme == null)? 0 :this.scheme.hashCode())); result = ((result* 31)+((this.databaseName == null)? 0 :this.databaseName.hashCode())); result = ((result* 31)+((this.supportsProfiler == null)? 0 :this.supportsProfiler.hashCode())); result = ((result* 31)+((this.sampleDataStorageConfig == null)? 0 :this.sampleDataStorageConfig.hashCode())); result = ((result* 31)+((this.type == null)? 0 :this.type.hashCode())); result = ((result* 31)+((this.kerberosServiceName == null)? 0 :this.kerberosServiceName.hashCode())); result = ((result* 31)+((this.supportsDBTExtraction == null)? 0 :this.supportsDBTExtraction.hashCode())); result = ((result* 31)+((this.useSSL == null)? 0 :this.useSSL.hashCode())); result = ((result* 31)+((this.connectionArguments == null)? 0 :this.connectionArguments.hashCode())); result = ((result* 31)+((this.password == null)? 0 :this.password.hashCode())); result = ((result* 31)+((this.authMechanism == null)? 0 :this.authMechanism.hashCode())); result = ((result* 31)+((this.connectionOptions == null)? 0 :this.connectionOptions.hashCode())); result = ((result* 31)+((this.hostPort == null)? 0 :this.hostPort.hashCode())); result = ((result* 31)+((this.supportsViewLineageExtraction == null)? 0 :this.supportsViewLineageExtraction.hashCode())); result = ((result* 31)+((this.username == null)? 0 :this.username.hashCode())); return result; } @Override public boolean equals(Object other) { if (other == this) { return true; } if ((other instanceof ImpalaConnection) == false) { return false; } ImpalaConnection rhs = ((ImpalaConnection) other); return (((((((((((((((((((this.databaseSchema == rhs.databaseSchema)||((this.databaseSchema!= null)&&this.databaseSchema.equals(rhs.databaseSchema)))&&((this.supportsMetadataExtraction == rhs.supportsMetadataExtraction)||((this.supportsMetadataExtraction!= null)&&this.supportsMetadataExtraction.equals(rhs.supportsMetadataExtraction))))&&((this.authOptions == rhs.authOptions)||((this.authOptions!= null)&&this.authOptions.equals(rhs.authOptions))))&&((this.scheme == rhs.scheme)||((this.scheme!= null)&&this.scheme.equals(rhs.scheme))))&&((this.databaseName == rhs.databaseName)||((this.databaseName!= null)&&this.databaseName.equals(rhs.databaseName))))&&((this.supportsProfiler == rhs.supportsProfiler)||((this.supportsProfiler!= null)&&this.supportsProfiler.equals(rhs.supportsProfiler))))&&((this.sampleDataStorageConfig == rhs.sampleDataStorageConfig)||((this.sampleDataStorageConfig!= null)&&this.sampleDataStorageConfig.equals(rhs.sampleDataStorageConfig))))&&((this.type == rhs.type)||((this.type!= null)&&this.type.equals(rhs.type))))&&((this.kerberosServiceName == rhs.kerberosServiceName)||((this.kerberosServiceName!= null)&&this.kerberosServiceName.equals(rhs.kerberosServiceName))))&&((this.supportsDBTExtraction == rhs.supportsDBTExtraction)||((this.supportsDBTExtraction!= null)&&this.supportsDBTExtraction.equals(rhs.supportsDBTExtraction))))&&((this.useSSL == rhs.useSSL)||((this.useSSL!= null)&&this.useSSL.equals(rhs.useSSL))))&&((this.connectionArguments == rhs.connectionArguments)||((this.connectionArguments!= null)&&this.connectionArguments.equals(rhs.connectionArguments))))&&((this.password == rhs.password)||((this.password!= null)&&this.password.equals(rhs.password))))&&((this.authMechanism == rhs.authMechanism)||((this.authMechanism!= null)&&this.authMechanism.equals(rhs.authMechanism))))&&((this.connectionOptions == rhs.connectionOptions)||((this.connectionOptions!= null)&&this.connectionOptions.equals(rhs.connectionOptions))))&&((this.hostPort == rhs.hostPort)||((this.hostPort!= null)&&this.hostPort.equals(rhs.hostPort))))&&((this.supportsViewLineageExtraction == rhs.supportsViewLineageExtraction)||((this.supportsViewLineageExtraction!= null)&&this.supportsViewLineageExtraction.equals(rhs.supportsViewLineageExtraction))))&&((this.username == rhs.username)||((this.username!= null)&&this.username.equals(rhs.username)))); } /** * Authentication Mode *

* Authentication mode to connect to Impala. * */ @Generated("jsonschema2pojo") public enum AuthMechanism { NOSASL("NOSASL"), PLAIN("PLAIN"), GSSAPI("GSSAPI"), LDAP("LDAP"), JWT("JWT"); private final String value; private final static Map CONSTANTS = new HashMap(); static { for (ImpalaConnection.AuthMechanism c: values()) { CONSTANTS.put(c.value, c); } } AuthMechanism(String value) { this.value = value; } @Override public String toString() { return this.value; } @JsonValue public String value() { return this.value; } @JsonCreator public static ImpalaConnection.AuthMechanism fromValue(String value) { ImpalaConnection.AuthMechanism constant = CONSTANTS.get(value); if (constant == null) { throw new IllegalArgumentException(value); } else { return constant; } } } /** * SQLAlchemy driver scheme options. * */ @Generated("jsonschema2pojo") public enum ImpalaScheme { IMPALA("impala"), IMPALA_4("impala4"); private final String value; private final static Map CONSTANTS = new HashMap(); static { for (ImpalaConnection.ImpalaScheme c: values()) { CONSTANTS.put(c.value, c); } } ImpalaScheme(String value) { this.value = value; } @Override public String toString() { return this.value; } @JsonValue public String value() { return this.value; } @JsonCreator public static ImpalaConnection.ImpalaScheme fromValue(String value) { ImpalaConnection.ImpalaScheme constant = CONSTANTS.get(value); if (constant == null) { throw new IllegalArgumentException(value); } else { return constant; } } } /** * Service type. * */ @Generated("jsonschema2pojo") public enum ImpalaType { IMPALA("Impala"); private final String value; private final static Map CONSTANTS = new HashMap(); static { for (ImpalaConnection.ImpalaType c: values()) { CONSTANTS.put(c.value, c); } } ImpalaType(String value) { this.value = value; } @Override public String toString() { return this.value; } @JsonValue public String value() { return this.value; } @JsonCreator public static ImpalaConnection.ImpalaType fromValue(String value) { ImpalaConnection.ImpalaType constant = CONSTANTS.get(value); if (constant == null) { throw new IllegalArgumentException(value); } else { return constant; } } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy