org.odpi.openmetadata.accessservices.digitalarchitecture.metadataelements.ValidValueAssignmentDefinitionElement Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of digital-architecture-api Show documentation
Show all versions of digital-architecture-api Show documentation
API classes for the Digital Architecture Open Metadata Access Service (OMAS).
The newest version!
/* SPDX-License-Identifier: Apache-2.0 */
/* Copyright Contributors to the ODPi Egeria project. */
package org.odpi.openmetadata.accessservices.digitalarchitecture.metadataelements;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import org.odpi.openmetadata.accessservices.digitalarchitecture.properties.ValidValueAssignmentProperties;
import java.util.Objects;
import static com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility.NONE;
import static com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility.PUBLIC_ONLY;
/**
* ValidValueAssignmentConsumerElement describes a a valid values set/definition that is
* defining the values that may/must be assigned to a referenceable.
*/
@JsonAutoDetect(getterVisibility=PUBLIC_ONLY, setterVisibility=PUBLIC_ONLY, fieldVisibility=NONE)
@JsonInclude(JsonInclude.Include.NON_NULL)
@JsonIgnoreProperties(ignoreUnknown=true)
public class ValidValueAssignmentDefinitionElement extends ValidValueAssignmentProperties
{
private ValidValueElement validValueElement = null;
/**
* Default constructor
*/
public ValidValueAssignmentDefinitionElement()
{
super();
}
/**
* Copy/clone constructor
*
* @param template object to copy
*/
public ValidValueAssignmentDefinitionElement(ValidValueAssignmentDefinitionElement template)
{
super(template);
if (template != null)
{
validValueElement = template.getValidValueElement();
}
}
/**
* Return the valid value bean (may be a definition or a set).
*
* @return bean
*/
public ValidValueElement getValidValueElement()
{
return validValueElement;
}
/**
* Set up the valid value bean (may be a definition or a set).
*
* @param validValueElement bean
*/
public void setValidValueElement(ValidValueElement validValueElement)
{
this.validValueElement = validValueElement;
}
/**
* JSON-style toString
*
* @return return string containing the property names and values
*/
@Override
public String toString()
{
return "ValidValueAssignmentDefinitionElement{" + "definition=" + validValueElement + ", strictRequirement=" + getStrictRequirement() + '}';
}
/**
* Return comparison result based on the content of the properties.
*
* @param objectToCompare test object
* @return result of comparison
*/
@Override
public boolean equals(Object objectToCompare)
{
if (this == objectToCompare)
{
return true;
}
if (objectToCompare == null || getClass() != objectToCompare.getClass())
{
return false;
}
if (!super.equals(objectToCompare))
{
return false;
}
ValidValueAssignmentDefinitionElement that = (ValidValueAssignmentDefinitionElement) objectToCompare;
return Objects.equals(validValueElement, that.validValueElement);
}
/**
* Return hash code for this object
*
* @return int hash code
*/
@Override
public int hashCode()
{
return Objects.hash(super.hashCode(), validValueElement);
}
}