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

com.oracle.bmc.mediaservices.model.ResourceLock Maven / Gradle / Ivy

Go to download

This project contains the SDK distribution used for Oracle Cloud Infrastructure, and all the dependencies that can be shaded. It also has Maven dependencies that cannot be shaded. Therefore, use this module to depend on the shaded distribution via Maven -- it will shade everything that can be shaded, and automatically pull in the other dependencies.

There is a newer version: 3.55.2
Show newest version
/**
 * Copyright (c) 2016, 2024, 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.mediaservices.model;

/**
 * Resource locks are used to prevent certain APIs from being called for the resource. A full lock
 * prevents both updating the resource and deleting the resource. A delete lock prevents deleting
 * the resource. 
* 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 Builder#__explicitlySet__}. The {@link * #hashCode()} and {@link #equals(Object)} methods are implemented to take the explicitly set * fields into account. The constructor, on the other hand, does not take the explicitly set fields * into account (since the constructor cannot distinguish explicit {@code null} from unset {@code * null}). */ @jakarta.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20211101") @com.fasterxml.jackson.databind.annotation.JsonDeserialize(builder = ResourceLock.Builder.class) @com.fasterxml.jackson.annotation.JsonFilter( com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel.EXPLICITLY_SET_FILTER_NAME) public final class ResourceLock extends com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel { @Deprecated @java.beans.ConstructorProperties({ "type", "compartmentId", "relatedResourceId", "message", "timeCreated" }) public ResourceLock( Type type, String compartmentId, String relatedResourceId, String message, java.util.Date timeCreated) { super(); this.type = type; this.compartmentId = compartmentId; this.relatedResourceId = relatedResourceId; this.message = message; this.timeCreated = timeCreated; } @com.fasterxml.jackson.databind.annotation.JsonPOJOBuilder(withPrefix = "") public static class Builder { /** Type of the lock. */ @com.fasterxml.jackson.annotation.JsonProperty("type") private Type type; /** * Type of the lock. * * @param type the value to set * @return this builder */ public Builder type(Type type) { this.type = type; this.__explicitlySet__.add("type"); return this; } /** The compartment ID of the lock. */ @com.fasterxml.jackson.annotation.JsonProperty("compartmentId") private String compartmentId; /** * The compartment ID of the lock. * * @param compartmentId the value to set * @return this builder */ public Builder compartmentId(String compartmentId) { this.compartmentId = compartmentId; this.__explicitlySet__.add("compartmentId"); return this; } /** * The ID of the resource that is locking this resource. Indicates that deleting this * resource will remove the lock. */ @com.fasterxml.jackson.annotation.JsonProperty("relatedResourceId") private String relatedResourceId; /** * The ID of the resource that is locking this resource. Indicates that deleting this * resource will remove the lock. * * @param relatedResourceId the value to set * @return this builder */ public Builder relatedResourceId(String relatedResourceId) { this.relatedResourceId = relatedResourceId; this.__explicitlySet__.add("relatedResourceId"); return this; } /** * A message added by the creator of the lock. This is typically used to give an indication * of why the resource is locked. */ @com.fasterxml.jackson.annotation.JsonProperty("message") private String message; /** * A message added by the creator of the lock. This is typically used to give an indication * of why the resource is locked. * * @param message the value to set * @return this builder */ public Builder message(String message) { this.message = message; this.__explicitlySet__.add("message"); return this; } /** When the lock was created. */ @com.fasterxml.jackson.annotation.JsonProperty("timeCreated") private java.util.Date timeCreated; /** * When the lock was created. * * @param timeCreated the value to set * @return this builder */ public Builder timeCreated(java.util.Date timeCreated) { this.timeCreated = timeCreated; this.__explicitlySet__.add("timeCreated"); return this; } @com.fasterxml.jackson.annotation.JsonIgnore private final java.util.Set __explicitlySet__ = new java.util.HashSet(); public ResourceLock build() { ResourceLock model = new ResourceLock( this.type, this.compartmentId, this.relatedResourceId, this.message, this.timeCreated); for (String explicitlySetProperty : this.__explicitlySet__) { model.markPropertyAsExplicitlySet(explicitlySetProperty); } return model; } @com.fasterxml.jackson.annotation.JsonIgnore public Builder copy(ResourceLock model) { if (model.wasPropertyExplicitlySet("type")) { this.type(model.getType()); } if (model.wasPropertyExplicitlySet("compartmentId")) { this.compartmentId(model.getCompartmentId()); } if (model.wasPropertyExplicitlySet("relatedResourceId")) { this.relatedResourceId(model.getRelatedResourceId()); } if (model.wasPropertyExplicitlySet("message")) { this.message(model.getMessage()); } if (model.wasPropertyExplicitlySet("timeCreated")) { this.timeCreated(model.getTimeCreated()); } return this; } } /** Create a new builder. */ public static Builder builder() { return new Builder(); } public Builder toBuilder() { return new Builder().copy(this); } /** Type of the lock. */ public enum Type implements com.oracle.bmc.http.internal.BmcEnum { Full("FULL"), Delete("DELETE"), /** * 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(Type.class); private final String value; private static java.util.Map map; static { map = new java.util.HashMap<>(); for (Type v : Type.values()) { if (v != UnknownEnumValue) { map.put(v.getValue(), v); } } } Type(String value) { this.value = value; } @com.fasterxml.jackson.annotation.JsonValue public String getValue() { return value; } @com.fasterxml.jackson.annotation.JsonCreator public static Type create(String key) { if (map.containsKey(key)) { return map.get(key); } LOG.warn( "Received unknown value '{}' for enum 'Type', returning UnknownEnumValue", key); return UnknownEnumValue; } }; /** Type of the lock. */ @com.fasterxml.jackson.annotation.JsonProperty("type") private final Type type; /** * Type of the lock. * * @return the value */ public Type getType() { return type; } /** The compartment ID of the lock. */ @com.fasterxml.jackson.annotation.JsonProperty("compartmentId") private final String compartmentId; /** * The compartment ID of the lock. * * @return the value */ public String getCompartmentId() { return compartmentId; } /** * The ID of the resource that is locking this resource. Indicates that deleting this resource * will remove the lock. */ @com.fasterxml.jackson.annotation.JsonProperty("relatedResourceId") private final String relatedResourceId; /** * The ID of the resource that is locking this resource. Indicates that deleting this resource * will remove the lock. * * @return the value */ public String getRelatedResourceId() { return relatedResourceId; } /** * A message added by the creator of the lock. This is typically used to give an indication of * why the resource is locked. */ @com.fasterxml.jackson.annotation.JsonProperty("message") private final String message; /** * A message added by the creator of the lock. This is typically used to give an indication of * why the resource is locked. * * @return the value */ public String getMessage() { return message; } /** When the lock was created. */ @com.fasterxml.jackson.annotation.JsonProperty("timeCreated") private final java.util.Date timeCreated; /** * When the lock was created. * * @return the value */ public java.util.Date getTimeCreated() { return timeCreated; } @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("ResourceLock("); sb.append("super=").append(super.toString()); sb.append("type=").append(String.valueOf(this.type)); sb.append(", compartmentId=").append(String.valueOf(this.compartmentId)); sb.append(", relatedResourceId=").append(String.valueOf(this.relatedResourceId)); sb.append(", message=").append(String.valueOf(this.message)); sb.append(", timeCreated=").append(String.valueOf(this.timeCreated)); sb.append(")"); return sb.toString(); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof ResourceLock)) { return false; } ResourceLock other = (ResourceLock) o; return java.util.Objects.equals(this.type, other.type) && java.util.Objects.equals(this.compartmentId, other.compartmentId) && java.util.Objects.equals(this.relatedResourceId, other.relatedResourceId) && java.util.Objects.equals(this.message, other.message) && java.util.Objects.equals(this.timeCreated, other.timeCreated) && super.equals(other); } @Override public int hashCode() { final int PRIME = 59; int result = 1; result = (result * PRIME) + (this.type == null ? 43 : this.type.hashCode()); result = (result * PRIME) + (this.compartmentId == null ? 43 : this.compartmentId.hashCode()); result = (result * PRIME) + (this.relatedResourceId == null ? 43 : this.relatedResourceId.hashCode()); result = (result * PRIME) + (this.message == null ? 43 : this.message.hashCode()); result = (result * PRIME) + (this.timeCreated == null ? 43 : this.timeCreated.hashCode()); result = (result * PRIME) + super.hashCode(); return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy