com.oracle.bmc.dataintegration.model.FunctionLibrarySummary Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of oci-java-sdk-dataintegration Show documentation
Show all versions of oci-java-sdk-dataintegration Show documentation
This project contains the SDK used for Oracle Cloud Infrastructure Data Integration
/**
* Copyright (c) 2016, 2022, Oracle and/or its affiliates. All rights reserved.
* This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
*/
package com.oracle.bmc.dataintegration.model;
/**
* The FunctionLibrary summary type contains the audit summary information and the definition of the
* Function Library.
* Note: Objects should always be created or deserialized using the {@link Builder}. This model
* distinguishes fields that are {@code null} because they are unset from fields that are explicitly
* set to {@code null}. This is done in the setter methods of the {@link Builder}, which maintain a
* set of all explicitly set fields called {@link #__explicitlySet__}. The {@link #hashCode()} and
* {@link #equals(Object)} methods are implemented to take {@link #__explicitlySet__} into account.
* The constructor, on the other hand, does not set {@link #__explicitlySet__} (since the
* constructor cannot distinguish explicit {@code null} from unset {@code null}).
*/
@javax.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20200430")
@com.fasterxml.jackson.databind.annotation.JsonDeserialize(
builder = FunctionLibrarySummary.Builder.class)
@com.fasterxml.jackson.annotation.JsonFilter(
com.oracle.bmc.http.client.internal.ExplicitlySetFilter.NAME)
public final class FunctionLibrarySummary
extends com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel {
@Deprecated
@java.beans.ConstructorProperties({
"key",
"modelType",
"modelVersion",
"name",
"description",
"categoryName",
"objectStatus",
"identifier",
"parentRef",
"objectVersion",
"metadata",
"keyMap"
})
public FunctionLibrarySummary(
String key,
ModelType modelType,
String modelVersion,
String name,
String description,
String categoryName,
Integer objectStatus,
String identifier,
ParentReference parentRef,
Integer objectVersion,
ObjectMetadata metadata,
java.util.Map keyMap) {
super();
this.key = key;
this.modelType = modelType;
this.modelVersion = modelVersion;
this.name = name;
this.description = description;
this.categoryName = categoryName;
this.objectStatus = objectStatus;
this.identifier = identifier;
this.parentRef = parentRef;
this.objectVersion = objectVersion;
this.metadata = metadata;
this.keyMap = keyMap;
}
@com.fasterxml.jackson.databind.annotation.JsonPOJOBuilder(withPrefix = "")
public static class Builder {
/** Generated key that can be used in API calls to identify FunctionLibrary. */
@com.fasterxml.jackson.annotation.JsonProperty("key")
private String key;
/**
* Generated key that can be used in API calls to identify FunctionLibrary.
*
* @param key the value to set
* @return this builder
*/
public Builder key(String key) {
this.key = key;
this.__explicitlySet__.add("key");
return this;
}
/** The type of the object. */
@com.fasterxml.jackson.annotation.JsonProperty("modelType")
private ModelType modelType;
/**
* The type of the object.
*
* @param modelType the value to set
* @return this builder
*/
public Builder modelType(ModelType modelType) {
this.modelType = modelType;
this.__explicitlySet__.add("modelType");
return this;
}
/** The model version of an object. */
@com.fasterxml.jackson.annotation.JsonProperty("modelVersion")
private String modelVersion;
/**
* The model version of an object.
*
* @param modelVersion the value to set
* @return this builder
*/
public Builder modelVersion(String modelVersion) {
this.modelVersion = modelVersion;
this.__explicitlySet__.add("modelVersion");
return this;
}
/**
* Free form text without any restriction on permitted characters. Name can have letters,
* numbers, and special characters. The value is editable and is restricted to 1000
* characters.
*/
@com.fasterxml.jackson.annotation.JsonProperty("name")
private String name;
/**
* Free form text without any restriction on permitted characters. Name can have letters,
* numbers, and special characters. The value is editable and is restricted to 1000
* characters.
*
* @param name the value to set
* @return this builder
*/
public Builder name(String name) {
this.name = name;
this.__explicitlySet__.add("name");
return this;
}
/** A user defined description for the Function Library. */
@com.fasterxml.jackson.annotation.JsonProperty("description")
private String description;
/**
* A user defined description for the Function Library.
*
* @param description the value to set
* @return this builder
*/
public Builder description(String description) {
this.description = description;
this.__explicitlySet__.add("description");
return this;
}
/** The category name. */
@com.fasterxml.jackson.annotation.JsonProperty("categoryName")
private String categoryName;
/**
* The category name.
*
* @param categoryName the value to set
* @return this builder
*/
public Builder categoryName(String categoryName) {
this.categoryName = categoryName;
this.__explicitlySet__.add("categoryName");
return this;
}
/**
* The status of an object that can be set to value 1 for shallow references across objects,
* other values reserved.
*/
@com.fasterxml.jackson.annotation.JsonProperty("objectStatus")
private Integer objectStatus;
/**
* The status of an object that can be set to value 1 for shallow references across objects,
* other values reserved.
*
* @param objectStatus the value to set
* @return this builder
*/
public Builder objectStatus(Integer objectStatus) {
this.objectStatus = objectStatus;
this.__explicitlySet__.add("objectStatus");
return this;
}
/**
* Value can only contain upper case letters, underscore, and numbers. It should begin with
* upper case letter or underscore. The value can be modified.
*/
@com.fasterxml.jackson.annotation.JsonProperty("identifier")
private String identifier;
/**
* Value can only contain upper case letters, underscore, and numbers. It should begin with
* upper case letter or underscore. The value can be modified.
*
* @param identifier the value to set
* @return this builder
*/
public Builder identifier(String identifier) {
this.identifier = identifier;
this.__explicitlySet__.add("identifier");
return this;
}
@com.fasterxml.jackson.annotation.JsonProperty("parentRef")
private ParentReference parentRef;
public Builder parentRef(ParentReference parentRef) {
this.parentRef = parentRef;
this.__explicitlySet__.add("parentRef");
return this;
}
/** The version of the object that is used to track changes in the object instance. */
@com.fasterxml.jackson.annotation.JsonProperty("objectVersion")
private Integer objectVersion;
/**
* The version of the object that is used to track changes in the object instance.
*
* @param objectVersion the value to set
* @return this builder
*/
public Builder objectVersion(Integer objectVersion) {
this.objectVersion = objectVersion;
this.__explicitlySet__.add("objectVersion");
return this;
}
@com.fasterxml.jackson.annotation.JsonProperty("metadata")
private ObjectMetadata metadata;
public Builder metadata(ObjectMetadata metadata) {
this.metadata = metadata;
this.__explicitlySet__.add("metadata");
return this;
}
/**
* A key map. If provided, the key is replaced with generated key. This structure provides
* mapping between user provided key and generated key.
*/
@com.fasterxml.jackson.annotation.JsonProperty("keyMap")
private java.util.Map keyMap;
/**
* A key map. If provided, the key is replaced with generated key. This structure provides
* mapping between user provided key and generated key.
*
* @param keyMap the value to set
* @return this builder
*/
public Builder keyMap(java.util.Map keyMap) {
this.keyMap = keyMap;
this.__explicitlySet__.add("keyMap");
return this;
}
@com.fasterxml.jackson.annotation.JsonIgnore
private final java.util.Set __explicitlySet__ = new java.util.HashSet();
public FunctionLibrarySummary build() {
FunctionLibrarySummary model =
new FunctionLibrarySummary(
this.key,
this.modelType,
this.modelVersion,
this.name,
this.description,
this.categoryName,
this.objectStatus,
this.identifier,
this.parentRef,
this.objectVersion,
this.metadata,
this.keyMap);
for (String explicitlySetProperty : this.__explicitlySet__) {
model.markPropertyAsExplicitlySet(explicitlySetProperty);
}
return model;
}
@com.fasterxml.jackson.annotation.JsonIgnore
public Builder copy(FunctionLibrarySummary model) {
if (model.wasPropertyExplicitlySet("key")) {
this.key(model.getKey());
}
if (model.wasPropertyExplicitlySet("modelType")) {
this.modelType(model.getModelType());
}
if (model.wasPropertyExplicitlySet("modelVersion")) {
this.modelVersion(model.getModelVersion());
}
if (model.wasPropertyExplicitlySet("name")) {
this.name(model.getName());
}
if (model.wasPropertyExplicitlySet("description")) {
this.description(model.getDescription());
}
if (model.wasPropertyExplicitlySet("categoryName")) {
this.categoryName(model.getCategoryName());
}
if (model.wasPropertyExplicitlySet("objectStatus")) {
this.objectStatus(model.getObjectStatus());
}
if (model.wasPropertyExplicitlySet("identifier")) {
this.identifier(model.getIdentifier());
}
if (model.wasPropertyExplicitlySet("parentRef")) {
this.parentRef(model.getParentRef());
}
if (model.wasPropertyExplicitlySet("objectVersion")) {
this.objectVersion(model.getObjectVersion());
}
if (model.wasPropertyExplicitlySet("metadata")) {
this.metadata(model.getMetadata());
}
if (model.wasPropertyExplicitlySet("keyMap")) {
this.keyMap(model.getKeyMap());
}
return this;
}
}
/** Create a new builder. */
public static Builder builder() {
return new Builder();
}
public Builder toBuilder() {
return new Builder().copy(this);
}
/** Generated key that can be used in API calls to identify FunctionLibrary. */
@com.fasterxml.jackson.annotation.JsonProperty("key")
private final String key;
/**
* Generated key that can be used in API calls to identify FunctionLibrary.
*
* @return the value
*/
public String getKey() {
return key;
}
/** The type of the object. */
public enum ModelType implements com.oracle.bmc.http.internal.BmcEnum {
FunctionLibrary("FUNCTION_LIBRARY"),
/**
* This value is used if a service returns a value for this enum that is not recognized by
* this version of the SDK.
*/
UnknownEnumValue(null);
private static final org.slf4j.Logger LOG =
org.slf4j.LoggerFactory.getLogger(ModelType.class);
private final String value;
private static java.util.Map map;
static {
map = new java.util.HashMap<>();
for (ModelType v : ModelType.values()) {
if (v != UnknownEnumValue) {
map.put(v.getValue(), v);
}
}
}
ModelType(String value) {
this.value = value;
}
@com.fasterxml.jackson.annotation.JsonValue
public String getValue() {
return value;
}
@com.fasterxml.jackson.annotation.JsonCreator
public static ModelType create(String key) {
if (map.containsKey(key)) {
return map.get(key);
}
LOG.warn(
"Received unknown value '{}' for enum 'ModelType', returning UnknownEnumValue",
key);
return UnknownEnumValue;
}
};
/** The type of the object. */
@com.fasterxml.jackson.annotation.JsonProperty("modelType")
private final ModelType modelType;
/**
* The type of the object.
*
* @return the value
*/
public ModelType getModelType() {
return modelType;
}
/** The model version of an object. */
@com.fasterxml.jackson.annotation.JsonProperty("modelVersion")
private final String modelVersion;
/**
* The model version of an object.
*
* @return the value
*/
public String getModelVersion() {
return modelVersion;
}
/**
* Free form text without any restriction on permitted characters. Name can have letters,
* numbers, and special characters. The value is editable and is restricted to 1000 characters.
*/
@com.fasterxml.jackson.annotation.JsonProperty("name")
private final String name;
/**
* Free form text without any restriction on permitted characters. Name can have letters,
* numbers, and special characters. The value is editable and is restricted to 1000 characters.
*
* @return the value
*/
public String getName() {
return name;
}
/** A user defined description for the Function Library. */
@com.fasterxml.jackson.annotation.JsonProperty("description")
private final String description;
/**
* A user defined description for the Function Library.
*
* @return the value
*/
public String getDescription() {
return description;
}
/** The category name. */
@com.fasterxml.jackson.annotation.JsonProperty("categoryName")
private final String categoryName;
/**
* The category name.
*
* @return the value
*/
public String getCategoryName() {
return categoryName;
}
/**
* The status of an object that can be set to value 1 for shallow references across objects,
* other values reserved.
*/
@com.fasterxml.jackson.annotation.JsonProperty("objectStatus")
private final Integer objectStatus;
/**
* The status of an object that can be set to value 1 for shallow references across objects,
* other values reserved.
*
* @return the value
*/
public Integer getObjectStatus() {
return objectStatus;
}
/**
* Value can only contain upper case letters, underscore, and numbers. It should begin with
* upper case letter or underscore. The value can be modified.
*/
@com.fasterxml.jackson.annotation.JsonProperty("identifier")
private final String identifier;
/**
* Value can only contain upper case letters, underscore, and numbers. It should begin with
* upper case letter or underscore. The value can be modified.
*
* @return the value
*/
public String getIdentifier() {
return identifier;
}
@com.fasterxml.jackson.annotation.JsonProperty("parentRef")
private final ParentReference parentRef;
public ParentReference getParentRef() {
return parentRef;
}
/** The version of the object that is used to track changes in the object instance. */
@com.fasterxml.jackson.annotation.JsonProperty("objectVersion")
private final Integer objectVersion;
/**
* The version of the object that is used to track changes in the object instance.
*
* @return the value
*/
public Integer getObjectVersion() {
return objectVersion;
}
@com.fasterxml.jackson.annotation.JsonProperty("metadata")
private final ObjectMetadata metadata;
public ObjectMetadata getMetadata() {
return metadata;
}
/**
* A key map. If provided, the key is replaced with generated key. This structure provides
* mapping between user provided key and generated key.
*/
@com.fasterxml.jackson.annotation.JsonProperty("keyMap")
private final java.util.Map keyMap;
/**
* A key map. If provided, the key is replaced with generated key. This structure provides
* mapping between user provided key and generated key.
*
* @return the value
*/
public java.util.Map getKeyMap() {
return keyMap;
}
@Override
public String toString() {
return this.toString(true);
}
/**
* Return a string representation of the object.
*
* @param includeByteArrayContents true to include the full contents of byte arrays
* @return string representation
*/
public String toString(boolean includeByteArrayContents) {
java.lang.StringBuilder sb = new java.lang.StringBuilder();
sb.append("FunctionLibrarySummary(");
sb.append("super=").append(super.toString());
sb.append("key=").append(String.valueOf(this.key));
sb.append(", modelType=").append(String.valueOf(this.modelType));
sb.append(", modelVersion=").append(String.valueOf(this.modelVersion));
sb.append(", name=").append(String.valueOf(this.name));
sb.append(", description=").append(String.valueOf(this.description));
sb.append(", categoryName=").append(String.valueOf(this.categoryName));
sb.append(", objectStatus=").append(String.valueOf(this.objectStatus));
sb.append(", identifier=").append(String.valueOf(this.identifier));
sb.append(", parentRef=").append(String.valueOf(this.parentRef));
sb.append(", objectVersion=").append(String.valueOf(this.objectVersion));
sb.append(", metadata=").append(String.valueOf(this.metadata));
sb.append(", keyMap=").append(String.valueOf(this.keyMap));
sb.append(")");
return sb.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (!(o instanceof FunctionLibrarySummary)) {
return false;
}
FunctionLibrarySummary other = (FunctionLibrarySummary) o;
return java.util.Objects.equals(this.key, other.key)
&& java.util.Objects.equals(this.modelType, other.modelType)
&& java.util.Objects.equals(this.modelVersion, other.modelVersion)
&& java.util.Objects.equals(this.name, other.name)
&& java.util.Objects.equals(this.description, other.description)
&& java.util.Objects.equals(this.categoryName, other.categoryName)
&& java.util.Objects.equals(this.objectStatus, other.objectStatus)
&& java.util.Objects.equals(this.identifier, other.identifier)
&& java.util.Objects.equals(this.parentRef, other.parentRef)
&& java.util.Objects.equals(this.objectVersion, other.objectVersion)
&& java.util.Objects.equals(this.metadata, other.metadata)
&& java.util.Objects.equals(this.keyMap, other.keyMap)
&& super.equals(other);
}
@Override
public int hashCode() {
final int PRIME = 59;
int result = 1;
result = (result * PRIME) + (this.key == null ? 43 : this.key.hashCode());
result = (result * PRIME) + (this.modelType == null ? 43 : this.modelType.hashCode());
result = (result * PRIME) + (this.modelVersion == null ? 43 : this.modelVersion.hashCode());
result = (result * PRIME) + (this.name == null ? 43 : this.name.hashCode());
result = (result * PRIME) + (this.description == null ? 43 : this.description.hashCode());
result = (result * PRIME) + (this.categoryName == null ? 43 : this.categoryName.hashCode());
result = (result * PRIME) + (this.objectStatus == null ? 43 : this.objectStatus.hashCode());
result = (result * PRIME) + (this.identifier == null ? 43 : this.identifier.hashCode());
result = (result * PRIME) + (this.parentRef == null ? 43 : this.parentRef.hashCode());
result =
(result * PRIME)
+ (this.objectVersion == null ? 43 : this.objectVersion.hashCode());
result = (result * PRIME) + (this.metadata == null ? 43 : this.metadata.hashCode());
result = (result * PRIME) + (this.keyMap == null ? 43 : this.keyMap.hashCode());
result = (result * PRIME) + super.hashCode();
return result;
}
}