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

com.pulumi.azurenative.awsconnector.outputs.AwsEcrRepositoryPropertiesResponse Maven / Gradle / Ivy

// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***

package com.pulumi.azurenative.awsconnector.outputs;

import com.pulumi.azurenative.awsconnector.outputs.EncryptionConfigurationResponse;
import com.pulumi.azurenative.awsconnector.outputs.ImageScanningConfigurationResponse;
import com.pulumi.azurenative.awsconnector.outputs.LifecyclePolicyResponse;
import com.pulumi.azurenative.awsconnector.outputs.TagResponse;
import com.pulumi.core.annotations.CustomType;
import java.lang.Boolean;
import java.lang.Object;
import java.lang.String;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;

@CustomType
public final class AwsEcrRepositoryPropertiesResponse {
    /**
     * @return Property arn
     * 
     */
    private @Nullable String arn;
    /**
     * @return If true, deleting the repository force deletes the contents of the repository. If false, the repository must be empty before attempting to delete it. If true, deleting the repository force deletes the contents of the repository. Without a force delete, you can only delete empty repositories.
     * 
     */
    private @Nullable Boolean emptyOnDelete;
    /**
     * @return The encryption configuration for the repository. This determines how the contents of your repository are encrypted at rest. The encryption configuration for the repository. This determines how the contents of your repository are encrypted at rest. By default, when no encryption configuration is set or the ``AES256`` encryption type is used, Amazon ECR uses server-side encryption with Amazon S3-managed encryption keys which encrypts your data at rest using an AES-256 encryption algorithm. This does not require any action on your part. For more control over the encryption of the contents of your repository, you can use server-side encryption with KMSlong key stored in KMSlong (KMS) to encrypt your images. For more information, see [Amazon ECR encryption at rest](https://docs.aws.amazon.com/AmazonECR/latest/userguide/encryption-at-rest.html) in the *Amazon Elastic Container Registry User Guide*.
     * 
     */
    private @Nullable EncryptionConfigurationResponse encryptionConfiguration;
    /**
     * @return The image scanning configuration for the repository. This determines whether images are scanned for known vulnerabilities after being pushed to the repository. The image scanning configuration for a repository.
     * 
     */
    private @Nullable ImageScanningConfigurationResponse imageScanningConfiguration;
    /**
     * @return The tag mutability setting for the repository. If this parameter is omitted, the default setting of ``MUTABLE`` will be used which will allow image tags to be overwritten. If ``IMMUTABLE`` is specified, all image tags within the repository will be immutable which will prevent them from being overwritten.
     * 
     */
    private @Nullable String imageTagMutability;
    /**
     * @return Creates or updates a lifecycle policy. For information about lifecycle policy syntax, see [Lifecycle policy template](https://docs.aws.amazon.com/AmazonECR/latest/userguide/LifecyclePolicies.html). The ``LifecyclePolicy`` property type specifies a lifecycle policy. For information about lifecycle policy syntax, see [Lifecycle policy template](https://docs.aws.amazon.com/AmazonECR/latest/userguide/LifecyclePolicies.html) in the *Amazon ECR User Guide*.
     * 
     */
    private @Nullable LifecyclePolicyResponse lifecyclePolicy;
    /**
     * @return The name to use for the repository. The repository name may be specified on its own (such as ``nginx-web-app``) or it can be prepended with a namespace to group the repository into a category (such as ``project-a/nginx-web-app``). If you don't specify a name, CFNlong generates a unique physical ID and uses that ID for the repository name. For more information, see [Name type](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html). The repository name must start with a letter and can only contain lowercase letters, numbers, hyphens, underscores, and forward slashes.  If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name.
     * 
     */
    private @Nullable String repositoryName;
    /**
     * @return The JSON repository policy text to apply to the repository. For more information, see [Amazon ECR repository policies](https://docs.aws.amazon.com/AmazonECR/latest/userguide/repository-policy-examples.html) in the *Amazon Elastic Container Registry User Guide*.
     * 
     */
    private @Nullable Object repositoryPolicyText;
    /**
     * @return Property repositoryUri
     * 
     */
    private @Nullable String repositoryUri;
    /**
     * @return An array of key-value pairs to apply to this resource.
     * 
     */
    private @Nullable List tags;

    private AwsEcrRepositoryPropertiesResponse() {}
    /**
     * @return Property arn
     * 
     */
    public Optional arn() {
        return Optional.ofNullable(this.arn);
    }
    /**
     * @return If true, deleting the repository force deletes the contents of the repository. If false, the repository must be empty before attempting to delete it. If true, deleting the repository force deletes the contents of the repository. Without a force delete, you can only delete empty repositories.
     * 
     */
    public Optional emptyOnDelete() {
        return Optional.ofNullable(this.emptyOnDelete);
    }
    /**
     * @return The encryption configuration for the repository. This determines how the contents of your repository are encrypted at rest. The encryption configuration for the repository. This determines how the contents of your repository are encrypted at rest. By default, when no encryption configuration is set or the ``AES256`` encryption type is used, Amazon ECR uses server-side encryption with Amazon S3-managed encryption keys which encrypts your data at rest using an AES-256 encryption algorithm. This does not require any action on your part. For more control over the encryption of the contents of your repository, you can use server-side encryption with KMSlong key stored in KMSlong (KMS) to encrypt your images. For more information, see [Amazon ECR encryption at rest](https://docs.aws.amazon.com/AmazonECR/latest/userguide/encryption-at-rest.html) in the *Amazon Elastic Container Registry User Guide*.
     * 
     */
    public Optional encryptionConfiguration() {
        return Optional.ofNullable(this.encryptionConfiguration);
    }
    /**
     * @return The image scanning configuration for the repository. This determines whether images are scanned for known vulnerabilities after being pushed to the repository. The image scanning configuration for a repository.
     * 
     */
    public Optional imageScanningConfiguration() {
        return Optional.ofNullable(this.imageScanningConfiguration);
    }
    /**
     * @return The tag mutability setting for the repository. If this parameter is omitted, the default setting of ``MUTABLE`` will be used which will allow image tags to be overwritten. If ``IMMUTABLE`` is specified, all image tags within the repository will be immutable which will prevent them from being overwritten.
     * 
     */
    public Optional imageTagMutability() {
        return Optional.ofNullable(this.imageTagMutability);
    }
    /**
     * @return Creates or updates a lifecycle policy. For information about lifecycle policy syntax, see [Lifecycle policy template](https://docs.aws.amazon.com/AmazonECR/latest/userguide/LifecyclePolicies.html). The ``LifecyclePolicy`` property type specifies a lifecycle policy. For information about lifecycle policy syntax, see [Lifecycle policy template](https://docs.aws.amazon.com/AmazonECR/latest/userguide/LifecyclePolicies.html) in the *Amazon ECR User Guide*.
     * 
     */
    public Optional lifecyclePolicy() {
        return Optional.ofNullable(this.lifecyclePolicy);
    }
    /**
     * @return The name to use for the repository. The repository name may be specified on its own (such as ``nginx-web-app``) or it can be prepended with a namespace to group the repository into a category (such as ``project-a/nginx-web-app``). If you don't specify a name, CFNlong generates a unique physical ID and uses that ID for the repository name. For more information, see [Name type](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html). The repository name must start with a letter and can only contain lowercase letters, numbers, hyphens, underscores, and forward slashes.  If you specify a name, you cannot perform updates that require replacement of this resource. You can perform updates that require no or some interruption. If you must replace the resource, specify a new name.
     * 
     */
    public Optional repositoryName() {
        return Optional.ofNullable(this.repositoryName);
    }
    /**
     * @return The JSON repository policy text to apply to the repository. For more information, see [Amazon ECR repository policies](https://docs.aws.amazon.com/AmazonECR/latest/userguide/repository-policy-examples.html) in the *Amazon Elastic Container Registry User Guide*.
     * 
     */
    public Optional repositoryPolicyText() {
        return Optional.ofNullable(this.repositoryPolicyText);
    }
    /**
     * @return Property repositoryUri
     * 
     */
    public Optional repositoryUri() {
        return Optional.ofNullable(this.repositoryUri);
    }
    /**
     * @return An array of key-value pairs to apply to this resource.
     * 
     */
    public List tags() {
        return this.tags == null ? List.of() : this.tags;
    }

    public static Builder builder() {
        return new Builder();
    }

    public static Builder builder(AwsEcrRepositoryPropertiesResponse defaults) {
        return new Builder(defaults);
    }
    @CustomType.Builder
    public static final class Builder {
        private @Nullable String arn;
        private @Nullable Boolean emptyOnDelete;
        private @Nullable EncryptionConfigurationResponse encryptionConfiguration;
        private @Nullable ImageScanningConfigurationResponse imageScanningConfiguration;
        private @Nullable String imageTagMutability;
        private @Nullable LifecyclePolicyResponse lifecyclePolicy;
        private @Nullable String repositoryName;
        private @Nullable Object repositoryPolicyText;
        private @Nullable String repositoryUri;
        private @Nullable List tags;
        public Builder() {}
        public Builder(AwsEcrRepositoryPropertiesResponse defaults) {
    	      Objects.requireNonNull(defaults);
    	      this.arn = defaults.arn;
    	      this.emptyOnDelete = defaults.emptyOnDelete;
    	      this.encryptionConfiguration = defaults.encryptionConfiguration;
    	      this.imageScanningConfiguration = defaults.imageScanningConfiguration;
    	      this.imageTagMutability = defaults.imageTagMutability;
    	      this.lifecyclePolicy = defaults.lifecyclePolicy;
    	      this.repositoryName = defaults.repositoryName;
    	      this.repositoryPolicyText = defaults.repositoryPolicyText;
    	      this.repositoryUri = defaults.repositoryUri;
    	      this.tags = defaults.tags;
        }

        @CustomType.Setter
        public Builder arn(@Nullable String arn) {

            this.arn = arn;
            return this;
        }
        @CustomType.Setter
        public Builder emptyOnDelete(@Nullable Boolean emptyOnDelete) {

            this.emptyOnDelete = emptyOnDelete;
            return this;
        }
        @CustomType.Setter
        public Builder encryptionConfiguration(@Nullable EncryptionConfigurationResponse encryptionConfiguration) {

            this.encryptionConfiguration = encryptionConfiguration;
            return this;
        }
        @CustomType.Setter
        public Builder imageScanningConfiguration(@Nullable ImageScanningConfigurationResponse imageScanningConfiguration) {

            this.imageScanningConfiguration = imageScanningConfiguration;
            return this;
        }
        @CustomType.Setter
        public Builder imageTagMutability(@Nullable String imageTagMutability) {

            this.imageTagMutability = imageTagMutability;
            return this;
        }
        @CustomType.Setter
        public Builder lifecyclePolicy(@Nullable LifecyclePolicyResponse lifecyclePolicy) {

            this.lifecyclePolicy = lifecyclePolicy;
            return this;
        }
        @CustomType.Setter
        public Builder repositoryName(@Nullable String repositoryName) {

            this.repositoryName = repositoryName;
            return this;
        }
        @CustomType.Setter
        public Builder repositoryPolicyText(@Nullable Object repositoryPolicyText) {

            this.repositoryPolicyText = repositoryPolicyText;
            return this;
        }
        @CustomType.Setter
        public Builder repositoryUri(@Nullable String repositoryUri) {

            this.repositoryUri = repositoryUri;
            return this;
        }
        @CustomType.Setter
        public Builder tags(@Nullable List tags) {

            this.tags = tags;
            return this;
        }
        public Builder tags(TagResponse... tags) {
            return tags(List.of(tags));
        }
        public AwsEcrRepositoryPropertiesResponse build() {
            final var _resultValue = new AwsEcrRepositoryPropertiesResponse();
            _resultValue.arn = arn;
            _resultValue.emptyOnDelete = emptyOnDelete;
            _resultValue.encryptionConfiguration = encryptionConfiguration;
            _resultValue.imageScanningConfiguration = imageScanningConfiguration;
            _resultValue.imageTagMutability = imageTagMutability;
            _resultValue.lifecyclePolicy = lifecyclePolicy;
            _resultValue.repositoryName = repositoryName;
            _resultValue.repositoryPolicyText = repositoryPolicyText;
            _resultValue.repositoryUri = repositoryUri;
            _resultValue.tags = tags;
            return _resultValue;
        }
    }
}