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

com.oracle.bmc.identity.model.CreatePolicyDetails 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.identity.model;

/**
 * 
* 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: 20160918") @com.fasterxml.jackson.databind.annotation.JsonDeserialize( builder = CreatePolicyDetails.Builder.class) @com.fasterxml.jackson.annotation.JsonFilter( com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel.EXPLICITLY_SET_FILTER_NAME) public final class CreatePolicyDetails extends com.oracle.bmc.http.client.internal.ExplicitlySetBmcModel { @Deprecated @java.beans.ConstructorProperties({ "compartmentId", "name", "statements", "description", "versionDate", "freeformTags", "definedTags" }) public CreatePolicyDetails( String compartmentId, String name, java.util.List statements, String description, java.util.Date versionDate, java.util.Map freeformTags, java.util.Map> definedTags) { super(); this.compartmentId = compartmentId; this.name = name; this.statements = statements; this.description = description; this.versionDate = versionDate; this.freeformTags = freeformTags; this.definedTags = definedTags; } @com.fasterxml.jackson.databind.annotation.JsonPOJOBuilder(withPrefix = "") public static class Builder { /** * The OCID of the compartment containing the policy (either the tenancy or another * compartment). */ @com.fasterxml.jackson.annotation.JsonProperty("compartmentId") private String compartmentId; /** * The OCID of the compartment containing the policy (either the tenancy or another * compartment). * * @param compartmentId the value to set * @return this builder */ public Builder compartmentId(String compartmentId) { this.compartmentId = compartmentId; this.__explicitlySet__.add("compartmentId"); return this; } /** * The name you assign to the policy during creation. The name must be unique across all * policies in the tenancy and cannot be changed. */ @com.fasterxml.jackson.annotation.JsonProperty("name") private String name; /** * The name you assign to the policy during creation. The name must be unique across all * policies in the tenancy and cannot be changed. * * @param name the value to set * @return this builder */ public Builder name(String name) { this.name = name; this.__explicitlySet__.add("name"); return this; } /** * An array of policy statements written in the policy language. See [How Policies * Work](https://docs.cloud.oracle.com/Content/Identity/policieshow/how-policies-work.htm) * and [Common * Policies](https://docs.cloud.oracle.com/Content/Identity/policiescommon/commonpolicies.htm). */ @com.fasterxml.jackson.annotation.JsonProperty("statements") private java.util.List statements; /** * An array of policy statements written in the policy language. See [How Policies * Work](https://docs.cloud.oracle.com/Content/Identity/policieshow/how-policies-work.htm) * and [Common * Policies](https://docs.cloud.oracle.com/Content/Identity/policiescommon/commonpolicies.htm). * * @param statements the value to set * @return this builder */ public Builder statements(java.util.List statements) { this.statements = statements; this.__explicitlySet__.add("statements"); return this; } /** * The description you assign to the policy during creation. Does not have to be unique, and * it's changeable. */ @com.fasterxml.jackson.annotation.JsonProperty("description") private String description; /** * The description you assign to the policy during creation. Does not have to be unique, and * it's changeable. * * @param description the value to set * @return this builder */ public Builder description(String description) { this.description = description; this.__explicitlySet__.add("description"); return this; } /** * The version of the policy. If null or set to an empty string, when a request comes in for * authorization, the policy will be evaluated according to the current behavior of the * services at that moment. If set to a particular date (YYYY-MM-DD), the policy will be * evaluated according to the behavior of the services on that date. */ @com.fasterxml.jackson.annotation.JsonProperty("versionDate") private java.util.Date versionDate; /** * The version of the policy. If null or set to an empty string, when a request comes in for * authorization, the policy will be evaluated according to the current behavior of the * services at that moment. If set to a particular date (YYYY-MM-DD), the policy will be * evaluated according to the behavior of the services on that date. * * @param versionDate the value to set * @return this builder */ public Builder versionDate(java.util.Date versionDate) { this.versionDate = versionDate; this.__explicitlySet__.add("versionDate"); return this; } /** * Free-form tags for this resource. Each tag is a simple key-value pair with no predefined * name, type, or namespace. For more information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Department": "Finance"}} */ @com.fasterxml.jackson.annotation.JsonProperty("freeformTags") private java.util.Map freeformTags; /** * Free-form tags for this resource. Each tag is a simple key-value pair with no predefined * name, type, or namespace. For more information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Department": "Finance"}} * * @param freeformTags the value to set * @return this builder */ public Builder freeformTags(java.util.Map freeformTags) { this.freeformTags = freeformTags; this.__explicitlySet__.add("freeformTags"); return this; } /** * Defined tags for this resource. Each key is predefined and scoped to a namespace. For * more information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Operations": {"CostCenter": "42"}}} */ @com.fasterxml.jackson.annotation.JsonProperty("definedTags") private java.util.Map> definedTags; /** * Defined tags for this resource. Each key is predefined and scoped to a namespace. For * more information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Operations": {"CostCenter": "42"}}} * * @param definedTags the value to set * @return this builder */ public Builder definedTags( java.util.Map> definedTags) { this.definedTags = definedTags; this.__explicitlySet__.add("definedTags"); return this; } @com.fasterxml.jackson.annotation.JsonIgnore private final java.util.Set __explicitlySet__ = new java.util.HashSet(); public CreatePolicyDetails build() { CreatePolicyDetails model = new CreatePolicyDetails( this.compartmentId, this.name, this.statements, this.description, this.versionDate, this.freeformTags, this.definedTags); for (String explicitlySetProperty : this.__explicitlySet__) { model.markPropertyAsExplicitlySet(explicitlySetProperty); } return model; } @com.fasterxml.jackson.annotation.JsonIgnore public Builder copy(CreatePolicyDetails model) { if (model.wasPropertyExplicitlySet("compartmentId")) { this.compartmentId(model.getCompartmentId()); } if (model.wasPropertyExplicitlySet("name")) { this.name(model.getName()); } if (model.wasPropertyExplicitlySet("statements")) { this.statements(model.getStatements()); } if (model.wasPropertyExplicitlySet("description")) { this.description(model.getDescription()); } if (model.wasPropertyExplicitlySet("versionDate")) { this.versionDate(model.getVersionDate()); } if (model.wasPropertyExplicitlySet("freeformTags")) { this.freeformTags(model.getFreeformTags()); } if (model.wasPropertyExplicitlySet("definedTags")) { this.definedTags(model.getDefinedTags()); } return this; } } /** Create a new builder. */ public static Builder builder() { return new Builder(); } public Builder toBuilder() { return new Builder().copy(this); } /** * The OCID of the compartment containing the policy (either the tenancy or another * compartment). */ @com.fasterxml.jackson.annotation.JsonProperty("compartmentId") private final String compartmentId; /** * The OCID of the compartment containing the policy (either the tenancy or another * compartment). * * @return the value */ public String getCompartmentId() { return compartmentId; } /** * The name you assign to the policy during creation. The name must be unique across all * policies in the tenancy and cannot be changed. */ @com.fasterxml.jackson.annotation.JsonProperty("name") private final String name; /** * The name you assign to the policy during creation. The name must be unique across all * policies in the tenancy and cannot be changed. * * @return the value */ public String getName() { return name; } /** * An array of policy statements written in the policy language. See [How Policies * Work](https://docs.cloud.oracle.com/Content/Identity/policieshow/how-policies-work.htm) and * [Common * Policies](https://docs.cloud.oracle.com/Content/Identity/policiescommon/commonpolicies.htm). */ @com.fasterxml.jackson.annotation.JsonProperty("statements") private final java.util.List statements; /** * An array of policy statements written in the policy language. See [How Policies * Work](https://docs.cloud.oracle.com/Content/Identity/policieshow/how-policies-work.htm) and * [Common * Policies](https://docs.cloud.oracle.com/Content/Identity/policiescommon/commonpolicies.htm). * * @return the value */ public java.util.List getStatements() { return statements; } /** * The description you assign to the policy during creation. Does not have to be unique, and * it's changeable. */ @com.fasterxml.jackson.annotation.JsonProperty("description") private final String description; /** * The description you assign to the policy during creation. Does not have to be unique, and * it's changeable. * * @return the value */ public String getDescription() { return description; } /** * The version of the policy. If null or set to an empty string, when a request comes in for * authorization, the policy will be evaluated according to the current behavior of the services * at that moment. If set to a particular date (YYYY-MM-DD), the policy will be evaluated * according to the behavior of the services on that date. */ @com.fasterxml.jackson.annotation.JsonProperty("versionDate") private final java.util.Date versionDate; /** * The version of the policy. If null or set to an empty string, when a request comes in for * authorization, the policy will be evaluated according to the current behavior of the services * at that moment. If set to a particular date (YYYY-MM-DD), the policy will be evaluated * according to the behavior of the services on that date. * * @return the value */ public java.util.Date getVersionDate() { return versionDate; } /** * Free-form tags for this resource. Each tag is a simple key-value pair with no predefined * name, type, or namespace. For more information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Department": "Finance"}} */ @com.fasterxml.jackson.annotation.JsonProperty("freeformTags") private final java.util.Map freeformTags; /** * Free-form tags for this resource. Each tag is a simple key-value pair with no predefined * name, type, or namespace. For more information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Department": "Finance"}} * * @return the value */ public java.util.Map getFreeformTags() { return freeformTags; } /** * Defined tags for this resource. Each key is predefined and scoped to a namespace. For more * information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Operations": {"CostCenter": "42"}}} */ @com.fasterxml.jackson.annotation.JsonProperty("definedTags") private final java.util.Map> definedTags; /** * Defined tags for this resource. Each key is predefined and scoped to a namespace. For more * information, see [Resource * Tags](https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: * {@code {"Operations": {"CostCenter": "42"}}} * * @return the value */ public java.util.Map> getDefinedTags() { return definedTags; } @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("CreatePolicyDetails("); sb.append("super=").append(super.toString()); sb.append("compartmentId=").append(String.valueOf(this.compartmentId)); sb.append(", name=").append(String.valueOf(this.name)); sb.append(", statements=").append(String.valueOf(this.statements)); sb.append(", description=").append(String.valueOf(this.description)); sb.append(", versionDate=").append(String.valueOf(this.versionDate)); sb.append(", freeformTags=").append(String.valueOf(this.freeformTags)); sb.append(", definedTags=").append(String.valueOf(this.definedTags)); sb.append(")"); return sb.toString(); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof CreatePolicyDetails)) { return false; } CreatePolicyDetails other = (CreatePolicyDetails) o; return java.util.Objects.equals(this.compartmentId, other.compartmentId) && java.util.Objects.equals(this.name, other.name) && java.util.Objects.equals(this.statements, other.statements) && java.util.Objects.equals(this.description, other.description) && java.util.Objects.equals(this.versionDate, other.versionDate) && java.util.Objects.equals(this.freeformTags, other.freeformTags) && java.util.Objects.equals(this.definedTags, other.definedTags) && super.equals(other); } @Override public int hashCode() { final int PRIME = 59; int result = 1; result = (result * PRIME) + (this.compartmentId == null ? 43 : this.compartmentId.hashCode()); result = (result * PRIME) + (this.name == null ? 43 : this.name.hashCode()); result = (result * PRIME) + (this.statements == null ? 43 : this.statements.hashCode()); result = (result * PRIME) + (this.description == null ? 43 : this.description.hashCode()); result = (result * PRIME) + (this.versionDate == null ? 43 : this.versionDate.hashCode()); result = (result * PRIME) + (this.freeformTags == null ? 43 : this.freeformTags.hashCode()); result = (result * PRIME) + (this.definedTags == null ? 43 : this.definedTags.hashCode()); result = (result * PRIME) + super.hashCode(); return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy