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

io.github.cdklabs.cdk.verified.permissions.OpenIdConnectIdentityTokenConfiguration Maven / Gradle / Ivy

The newest version!
package io.github.cdklabs.cdk.verified.permissions;

/**
 */
@javax.annotation.Generated(value = "jsii-pacmak/1.103.1 (build bef2dea)", date = "2024-10-11T10:47:53.518Z")
@software.amazon.jsii.Jsii(module = io.github.cdklabs.cdk.verified.permissions.$Module.class, fqn = "@cdklabs/cdk-verified-permissions.OpenIdConnectIdentityTokenConfiguration")
@software.amazon.jsii.Jsii.Proxy(OpenIdConnectIdentityTokenConfiguration.Jsii$Proxy.class)
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental)
public interface OpenIdConnectIdentityTokenConfiguration extends software.amazon.jsii.JsiiSerializable {

    /**
     * (experimental) The ID token audience, or client ID, claim values that you want to accept in your policy store from an OIDC identity provider.
     * 

* Default: - no client IDs */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) default @org.jetbrains.annotations.Nullable java.util.List getClientIds() { return null; } /** * (experimental) The claim that determines the principal in OIDC access tokens. *

* Default: - no principal claim */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) default @org.jetbrains.annotations.Nullable java.lang.String getPrincipalIdClaim() { return null; } /** * @return a {@link Builder} of {@link OpenIdConnectIdentityTokenConfiguration} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) static Builder builder() { return new Builder(); } /** * A builder for {@link OpenIdConnectIdentityTokenConfiguration} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public static final class Builder implements software.amazon.jsii.Builder { java.util.List clientIds; java.lang.String principalIdClaim; /** * Sets the value of {@link OpenIdConnectIdentityTokenConfiguration#getClientIds} * @param clientIds The ID token audience, or client ID, claim values that you want to accept in your policy store from an OIDC identity provider. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder clientIds(java.util.List clientIds) { this.clientIds = clientIds; return this; } /** * Sets the value of {@link OpenIdConnectIdentityTokenConfiguration#getPrincipalIdClaim} * @param principalIdClaim The claim that determines the principal in OIDC access tokens. * @return {@code this} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) public Builder principalIdClaim(java.lang.String principalIdClaim) { this.principalIdClaim = principalIdClaim; return this; } /** * Builds the configured instance. * @return a new instance of {@link OpenIdConnectIdentityTokenConfiguration} * @throws NullPointerException if any required attribute was not provided */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @Override public OpenIdConnectIdentityTokenConfiguration build() { return new Jsii$Proxy(this); } } /** * An implementation for {@link OpenIdConnectIdentityTokenConfiguration} */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Experimental) @software.amazon.jsii.Internal final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements OpenIdConnectIdentityTokenConfiguration { private final java.util.List clientIds; private final java.lang.String principalIdClaim; /** * Constructor that initializes the object based on values retrieved from the JsiiObject. * @param objRef Reference to the JSII managed object. */ protected Jsii$Proxy(final software.amazon.jsii.JsiiObjectRef objRef) { super(objRef); this.clientIds = software.amazon.jsii.Kernel.get(this, "clientIds", software.amazon.jsii.NativeType.listOf(software.amazon.jsii.NativeType.forClass(java.lang.String.class))); this.principalIdClaim = software.amazon.jsii.Kernel.get(this, "principalIdClaim", software.amazon.jsii.NativeType.forClass(java.lang.String.class)); } /** * Constructor that initializes the object based on literal property values passed by the {@link Builder}. */ protected Jsii$Proxy(final Builder builder) { super(software.amazon.jsii.JsiiObject.InitializationMode.JSII); this.clientIds = builder.clientIds; this.principalIdClaim = builder.principalIdClaim; } @Override public final java.util.List getClientIds() { return this.clientIds; } @Override public final java.lang.String getPrincipalIdClaim() { return this.principalIdClaim; } @Override @software.amazon.jsii.Internal public com.fasterxml.jackson.databind.JsonNode $jsii$toJson() { final com.fasterxml.jackson.databind.ObjectMapper om = software.amazon.jsii.JsiiObjectMapper.INSTANCE; final com.fasterxml.jackson.databind.node.ObjectNode data = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); if (this.getClientIds() != null) { data.set("clientIds", om.valueToTree(this.getClientIds())); } if (this.getPrincipalIdClaim() != null) { data.set("principalIdClaim", om.valueToTree(this.getPrincipalIdClaim())); } final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); struct.set("fqn", om.valueToTree("@cdklabs/cdk-verified-permissions.OpenIdConnectIdentityTokenConfiguration")); struct.set("data", data); final com.fasterxml.jackson.databind.node.ObjectNode obj = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode(); obj.set("$jsii.struct", struct); return obj; } @Override public final boolean equals(final Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; OpenIdConnectIdentityTokenConfiguration.Jsii$Proxy that = (OpenIdConnectIdentityTokenConfiguration.Jsii$Proxy) o; if (this.clientIds != null ? !this.clientIds.equals(that.clientIds) : that.clientIds != null) return false; return this.principalIdClaim != null ? this.principalIdClaim.equals(that.principalIdClaim) : that.principalIdClaim == null; } @Override public final int hashCode() { int result = this.clientIds != null ? this.clientIds.hashCode() : 0; result = 31 * result + (this.principalIdClaim != null ? this.principalIdClaim.hashCode() : 0); return result; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy