com.pulumi.aws.rds.Snapshot Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws Show documentation
Show all versions of aws Show documentation
A Pulumi package for creating and managing Amazon Web Services (AWS) cloud resources.
// *** 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.aws.rds;
import com.pulumi.aws.Utilities;
import com.pulumi.aws.rds.SnapshotArgs;
import com.pulumi.aws.rds.inputs.SnapshotState;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Export;
import com.pulumi.core.annotations.ResourceType;
import com.pulumi.core.internal.Codegen;
import java.lang.Boolean;
import java.lang.Integer;
import java.lang.String;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import javax.annotation.Nullable;
/**
* Manages an RDS database instance snapshot. For managing RDS database cluster snapshots, see the `aws.rds.ClusterSnapshot` resource.
*
* ## Example Usage
*
* <!--Start PulumiCodeChooser -->
*
* {@code
* package generated_program;
*
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.aws.rds.Instance;
* import com.pulumi.aws.rds.InstanceArgs;
* import com.pulumi.aws.rds.Snapshot;
* import com.pulumi.aws.rds.SnapshotArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
*
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
*
* public static void stack(Context ctx) {
* var bar = new Instance("bar", InstanceArgs.builder()
* .allocatedStorage(10)
* .engine("mysql")
* .engineVersion("5.6.21")
* .instanceClass("db.t2.micro")
* .dbName("baz")
* .password("barbarbarbar")
* .username("foo")
* .maintenanceWindow("Fri:09:00-Fri:09:30")
* .backupRetentionPeriod(0)
* .parameterGroupName("default.mysql5.6")
* .build());
*
* var test = new Snapshot("test", SnapshotArgs.builder()
* .dbInstanceIdentifier(bar.identifier())
* .dbSnapshotIdentifier("testsnapshot1234")
* .build());
*
* }
* }
* }
*
* <!--End PulumiCodeChooser -->
*
* ## Import
*
* Using `pulumi import`, import `aws_db_snapshot` using the snapshot identifier. For example:
*
* ```sh
* $ pulumi import aws:rds/snapshot:Snapshot example my-snapshot
* ```
*
*/
@ResourceType(type="aws:rds/snapshot:Snapshot")
public class Snapshot extends com.pulumi.resources.CustomResource {
/**
* Specifies the allocated storage size in gigabytes (GB).
*
*/
@Export(name="allocatedStorage", refs={Integer.class}, tree="[0]")
private Output allocatedStorage;
/**
* @return Specifies the allocated storage size in gigabytes (GB).
*
*/
public Output allocatedStorage() {
return this.allocatedStorage;
}
/**
* Specifies the name of the Availability Zone the DB instance was located in at the time of the DB snapshot.
*
*/
@Export(name="availabilityZone", refs={String.class}, tree="[0]")
private Output availabilityZone;
/**
* @return Specifies the name of the Availability Zone the DB instance was located in at the time of the DB snapshot.
*
*/
public Output availabilityZone() {
return this.availabilityZone;
}
/**
* The DB Instance Identifier from which to take the snapshot.
*
*/
@Export(name="dbInstanceIdentifier", refs={String.class}, tree="[0]")
private Output dbInstanceIdentifier;
/**
* @return The DB Instance Identifier from which to take the snapshot.
*
*/
public Output dbInstanceIdentifier() {
return this.dbInstanceIdentifier;
}
/**
* The Amazon Resource Name (ARN) for the DB snapshot.
*
*/
@Export(name="dbSnapshotArn", refs={String.class}, tree="[0]")
private Output dbSnapshotArn;
/**
* @return The Amazon Resource Name (ARN) for the DB snapshot.
*
*/
public Output dbSnapshotArn() {
return this.dbSnapshotArn;
}
/**
* The Identifier for the snapshot.
*
*/
@Export(name="dbSnapshotIdentifier", refs={String.class}, tree="[0]")
private Output dbSnapshotIdentifier;
/**
* @return The Identifier for the snapshot.
*
*/
public Output dbSnapshotIdentifier() {
return this.dbSnapshotIdentifier;
}
/**
* Specifies whether the DB snapshot is encrypted.
*
*/
@Export(name="encrypted", refs={Boolean.class}, tree="[0]")
private Output encrypted;
/**
* @return Specifies whether the DB snapshot is encrypted.
*
*/
public Output encrypted() {
return this.encrypted;
}
/**
* Specifies the name of the database engine.
*
*/
@Export(name="engine", refs={String.class}, tree="[0]")
private Output engine;
/**
* @return Specifies the name of the database engine.
*
*/
public Output engine() {
return this.engine;
}
/**
* Specifies the version of the database engine.
*
*/
@Export(name="engineVersion", refs={String.class}, tree="[0]")
private Output engineVersion;
/**
* @return Specifies the version of the database engine.
*
*/
public Output engineVersion() {
return this.engineVersion;
}
/**
* Specifies the Provisioned IOPS (I/O operations per second) value of the DB instance at the time of the snapshot.
*
*/
@Export(name="iops", refs={Integer.class}, tree="[0]")
private Output iops;
/**
* @return Specifies the Provisioned IOPS (I/O operations per second) value of the DB instance at the time of the snapshot.
*
*/
public Output iops() {
return this.iops;
}
/**
* The ARN for the KMS encryption key.
*
*/
@Export(name="kmsKeyId", refs={String.class}, tree="[0]")
private Output kmsKeyId;
/**
* @return The ARN for the KMS encryption key.
*
*/
public Output kmsKeyId() {
return this.kmsKeyId;
}
/**
* License model information for the restored DB instance.
*
*/
@Export(name="licenseModel", refs={String.class}, tree="[0]")
private Output licenseModel;
/**
* @return License model information for the restored DB instance.
*
*/
public Output licenseModel() {
return this.licenseModel;
}
/**
* Provides the option group name for the DB snapshot.
*
*/
@Export(name="optionGroupName", refs={String.class}, tree="[0]")
private Output optionGroupName;
/**
* @return Provides the option group name for the DB snapshot.
*
*/
public Output optionGroupName() {
return this.optionGroupName;
}
@Export(name="port", refs={Integer.class}, tree="[0]")
private Output port;
public Output port() {
return this.port;
}
/**
* List of AWS Account ids to share snapshot with, use `all` to make snaphot public.
*
*/
@Export(name="sharedAccounts", refs={List.class,String.class}, tree="[0,1]")
private Output* @Nullable */ List> sharedAccounts;
/**
* @return List of AWS Account ids to share snapshot with, use `all` to make snaphot public.
*
*/
public Output>> sharedAccounts() {
return Codegen.optional(this.sharedAccounts);
}
@Export(name="snapshotType", refs={String.class}, tree="[0]")
private Output snapshotType;
public Output snapshotType() {
return this.snapshotType;
}
/**
* The DB snapshot Arn that the DB snapshot was copied from. It only has value in case of cross customer or cross region copy.
*
*/
@Export(name="sourceDbSnapshotIdentifier", refs={String.class}, tree="[0]")
private Output sourceDbSnapshotIdentifier;
/**
* @return The DB snapshot Arn that the DB snapshot was copied from. It only has value in case of cross customer or cross region copy.
*
*/
public Output sourceDbSnapshotIdentifier() {
return this.sourceDbSnapshotIdentifier;
}
/**
* The region that the DB snapshot was created in or copied from.
*
*/
@Export(name="sourceRegion", refs={String.class}, tree="[0]")
private Output sourceRegion;
/**
* @return The region that the DB snapshot was created in or copied from.
*
*/
public Output sourceRegion() {
return this.sourceRegion;
}
/**
* Specifies the status of this DB snapshot.
*
*/
@Export(name="status", refs={String.class}, tree="[0]")
private Output status;
/**
* @return Specifies the status of this DB snapshot.
*
*/
public Output status() {
return this.status;
}
/**
* Specifies the storage type associated with DB snapshot.
*
*/
@Export(name="storageType", refs={String.class}, tree="[0]")
private Output storageType;
/**
* @return Specifies the storage type associated with DB snapshot.
*
*/
public Output storageType() {
return this.storageType;
}
/**
* Key-value map of resource tags. .If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
*/
@Export(name="tags", refs={Map.class,String.class}, tree="[0,1,1]")
private Output* @Nullable */ Map> tags;
/**
* @return Key-value map of resource tags. .If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*
*/
public Output>> tags() {
return Codegen.optional(this.tags);
}
/**
* A map of tags assigned to the resource, including those inherited from the provider `default_tags` configuration block.
*
* @deprecated
* Please use `tags` instead.
*
*/
@Deprecated /* Please use `tags` instead. */
@Export(name="tagsAll", refs={Map.class,String.class}, tree="[0,1,1]")
private Output
© 2015 - 2025 Weber Informatics LLC | Privacy Policy