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

software.amazon.awscdk.services.secretsmanager.ResourcePolicy Maven / Gradle / Ivy

There is a newer version: 1.204.0
Show newest version
package software.amazon.awscdk.services.secretsmanager;

/**
 * Resource Policy for SecretsManager Secrets.
 * 

* Policies define the operations that are allowed on this resource. *

* You almost never need to define this construct directly. *

* All AWS resources that support resource policies have a method called * addToResourcePolicy(), which will automatically create a new resource * policy if one doesn't exist yet, otherwise it will add to the existing * policy. *

* Prefer to use addToResourcePolicy() instead. *

* Example: *

*

 * // The code below shows an example of how to instantiate this type.
 * // The values are placeholders you should change.
 * import software.amazon.awscdk.services.secretsmanager.*;
 * Secret secret;
 * ResourcePolicy resourcePolicy = ResourcePolicy.Builder.create(this, "MyResourcePolicy")
 *         .secret(secret)
 *         .build();
 * 
*/ @javax.annotation.Generated(value = "jsii-pacmak/1.72.0 (build 4b8828b)", date = "2022-12-21T20:56:28.087Z") @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) @software.amazon.jsii.Jsii(module = software.amazon.awscdk.services.secretsmanager.$Module.class, fqn = "@aws-cdk/aws-secretsmanager.ResourcePolicy") public class ResourcePolicy extends software.amazon.awscdk.core.Resource { protected ResourcePolicy(final software.amazon.jsii.JsiiObjectRef objRef) { super(objRef); } protected ResourcePolicy(final software.amazon.jsii.JsiiObject.InitializationMode initializationMode) { super(initializationMode); } /** * @param scope This parameter is required. * @param id This parameter is required. * @param props This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public ResourcePolicy(final @org.jetbrains.annotations.NotNull software.constructs.Construct scope, final @org.jetbrains.annotations.NotNull java.lang.String id, final @org.jetbrains.annotations.NotNull software.amazon.awscdk.services.secretsmanager.ResourcePolicyProps props) { super(software.amazon.jsii.JsiiObject.InitializationMode.JSII); software.amazon.jsii.JsiiEngine.getInstance().createNewObject(this, new Object[] { java.util.Objects.requireNonNull(scope, "scope is required"), java.util.Objects.requireNonNull(id, "id is required"), java.util.Objects.requireNonNull(props, "props is required") }); } /** * The IAM policy document for this policy. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public @org.jetbrains.annotations.NotNull software.amazon.awscdk.services.iam.PolicyDocument getDocument() { return software.amazon.jsii.Kernel.get(this, "document", software.amazon.jsii.NativeType.forClass(software.amazon.awscdk.services.iam.PolicyDocument.class)); } /** * A fluent builder for {@link software.amazon.awscdk.services.secretsmanager.ResourcePolicy}. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public static final class Builder implements software.amazon.jsii.Builder { /** * @return a new instance of {@link Builder}. * @param scope This parameter is required. * @param id This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public static Builder create(final software.constructs.Construct scope, final java.lang.String id) { return new Builder(scope, id); } private final software.constructs.Construct scope; private final java.lang.String id; private final software.amazon.awscdk.services.secretsmanager.ResourcePolicyProps.Builder props; private Builder(final software.constructs.Construct scope, final java.lang.String id) { this.scope = scope; this.id = id; this.props = new software.amazon.awscdk.services.secretsmanager.ResourcePolicyProps.Builder(); } /** * The secret to attach a resource-based permissions policy. *

* @return {@code this} * @param secret The secret to attach a resource-based permissions policy. This parameter is required. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) public Builder secret(final software.amazon.awscdk.services.secretsmanager.ISecret secret) { this.props.secret(secret); return this; } /** * @returns a newly built instance of {@link software.amazon.awscdk.services.secretsmanager.ResourcePolicy}. */ @software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable) @Override public software.amazon.awscdk.services.secretsmanager.ResourcePolicy build() { return new software.amazon.awscdk.services.secretsmanager.ResourcePolicy( this.scope, this.id, this.props.build() ); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy