All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.pulumi.alicloud.hbr.OssBackupPlanArgs Maven / Gradle / Ivy
Go to download
A Pulumi package for creating and managing AliCloud 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.alicloud.hbr;
import com.pulumi.core.Output;
import com.pulumi.core.annotations.Import;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import java.lang.Boolean;
import java.lang.Integer;
import java.lang.String;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
public final class OssBackupPlanArgs extends com.pulumi.resources.ResourceArgs {
public static final OssBackupPlanArgs Empty = new OssBackupPlanArgs();
/**
* Backup type. Valid values: `COMPLETE`.
*
*/
@Import(name="backupType", required=true)
private Output backupType;
/**
* @return Backup type. Valid values: `COMPLETE`.
*
*/
public Output backupType() {
return this.backupType;
}
/**
* The name of OSS bucket.
*
*/
@Import(name="bucket", required=true)
private Output bucket;
/**
* @return The name of OSS bucket.
*
*/
public Output bucket() {
return this.bucket;
}
/**
* The role name created in the original account RAM backup by the cross account managed by the current account.
*
*/
@Import(name="crossAccountRoleName")
private @Nullable Output crossAccountRoleName;
/**
* @return The role name created in the original account RAM backup by the cross account managed by the current account.
*
*/
public Optional> crossAccountRoleName() {
return Optional.ofNullable(this.crossAccountRoleName);
}
/**
* The type of the cross account backup. Valid values: `SELF_ACCOUNT`, `CROSS_ACCOUNT`.
*
*/
@Import(name="crossAccountType")
private @Nullable Output crossAccountType;
/**
* @return The type of the cross account backup. Valid values: `SELF_ACCOUNT`, `CROSS_ACCOUNT`.
*
*/
public Optional> crossAccountType() {
return Optional.ofNullable(this.crossAccountType);
}
/**
* The original account ID of the cross account backup managed by the current account.
*
*/
@Import(name="crossAccountUserId")
private @Nullable Output crossAccountUserId;
/**
* @return The original account ID of the cross account backup managed by the current account.
*
*/
public Optional> crossAccountUserId() {
return Optional.ofNullable(this.crossAccountUserId);
}
/**
* Whether to disable the backup task. Valid values: `true`, `false`.
*
*/
@Import(name="disabled")
private @Nullable Output disabled;
/**
* @return Whether to disable the backup task. Valid values: `true`, `false`.
*
*/
public Optional> disabled() {
return Optional.ofNullable(this.disabled);
}
/**
* The name of the backup plan. 1~64 characters, the backup plan name of each data source type in a single warehouse required to be unique.
*
*/
@Import(name="ossBackupPlanName", required=true)
private Output ossBackupPlanName;
/**
* @return The name of the backup plan. 1~64 characters, the backup plan name of each data source type in a single warehouse required to be unique.
*
*/
public Output ossBackupPlanName() {
return this.ossBackupPlanName;
}
/**
* Backup prefix. Once specified, only objects with matching prefixes will be backed up.
*
*/
@Import(name="prefix")
private @Nullable Output prefix;
/**
* @return Backup prefix. Once specified, only objects with matching prefixes will be backed up.
*
*/
public Optional> prefix() {
return Optional.ofNullable(this.prefix);
}
/**
* Backup retention days, the minimum is 1.
*
*/
@Import(name="retention", required=true)
private Output retention;
/**
* @return Backup retention days, the minimum is 1.
*
*/
public Output retention() {
return this.retention;
}
/**
* Backup strategy. Optional format: `I|{startTime}|{interval}`. It means to execute a backup task every `{interval}` starting from `{startTime}`. The backup task for the elapsed time will not be compensated. If the last backup task has not completed yet, the next backup task will not be triggered.
* * `startTime` Backup start time, UNIX time seconds.
*
*/
@Import(name="schedule", required=true)
private Output schedule;
/**
* @return Backup strategy. Optional format: `I|{startTime}|{interval}`. It means to execute a backup task every `{interval}` starting from `{startTime}`. The backup task for the elapsed time will not be compensated. If the last backup task has not completed yet, the next backup task will not be triggered.
* * `startTime` Backup start time, UNIX time seconds.
*
*/
public Output schedule() {
return this.schedule;
}
/**
* The ID of backup vault.
*
*/
@Import(name="vaultId", required=true)
private Output vaultId;
/**
* @return The ID of backup vault.
*
*/
public Output vaultId() {
return this.vaultId;
}
private OssBackupPlanArgs() {}
private OssBackupPlanArgs(OssBackupPlanArgs $) {
this.backupType = $.backupType;
this.bucket = $.bucket;
this.crossAccountRoleName = $.crossAccountRoleName;
this.crossAccountType = $.crossAccountType;
this.crossAccountUserId = $.crossAccountUserId;
this.disabled = $.disabled;
this.ossBackupPlanName = $.ossBackupPlanName;
this.prefix = $.prefix;
this.retention = $.retention;
this.schedule = $.schedule;
this.vaultId = $.vaultId;
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(OssBackupPlanArgs defaults) {
return new Builder(defaults);
}
public static final class Builder {
private OssBackupPlanArgs $;
public Builder() {
$ = new OssBackupPlanArgs();
}
public Builder(OssBackupPlanArgs defaults) {
$ = new OssBackupPlanArgs(Objects.requireNonNull(defaults));
}
/**
* @param backupType Backup type. Valid values: `COMPLETE`.
*
* @return builder
*
*/
public Builder backupType(Output backupType) {
$.backupType = backupType;
return this;
}
/**
* @param backupType Backup type. Valid values: `COMPLETE`.
*
* @return builder
*
*/
public Builder backupType(String backupType) {
return backupType(Output.of(backupType));
}
/**
* @param bucket The name of OSS bucket.
*
* @return builder
*
*/
public Builder bucket(Output bucket) {
$.bucket = bucket;
return this;
}
/**
* @param bucket The name of OSS bucket.
*
* @return builder
*
*/
public Builder bucket(String bucket) {
return bucket(Output.of(bucket));
}
/**
* @param crossAccountRoleName The role name created in the original account RAM backup by the cross account managed by the current account.
*
* @return builder
*
*/
public Builder crossAccountRoleName(@Nullable Output crossAccountRoleName) {
$.crossAccountRoleName = crossAccountRoleName;
return this;
}
/**
* @param crossAccountRoleName The role name created in the original account RAM backup by the cross account managed by the current account.
*
* @return builder
*
*/
public Builder crossAccountRoleName(String crossAccountRoleName) {
return crossAccountRoleName(Output.of(crossAccountRoleName));
}
/**
* @param crossAccountType The type of the cross account backup. Valid values: `SELF_ACCOUNT`, `CROSS_ACCOUNT`.
*
* @return builder
*
*/
public Builder crossAccountType(@Nullable Output crossAccountType) {
$.crossAccountType = crossAccountType;
return this;
}
/**
* @param crossAccountType The type of the cross account backup. Valid values: `SELF_ACCOUNT`, `CROSS_ACCOUNT`.
*
* @return builder
*
*/
public Builder crossAccountType(String crossAccountType) {
return crossAccountType(Output.of(crossAccountType));
}
/**
* @param crossAccountUserId The original account ID of the cross account backup managed by the current account.
*
* @return builder
*
*/
public Builder crossAccountUserId(@Nullable Output crossAccountUserId) {
$.crossAccountUserId = crossAccountUserId;
return this;
}
/**
* @param crossAccountUserId The original account ID of the cross account backup managed by the current account.
*
* @return builder
*
*/
public Builder crossAccountUserId(Integer crossAccountUserId) {
return crossAccountUserId(Output.of(crossAccountUserId));
}
/**
* @param disabled Whether to disable the backup task. Valid values: `true`, `false`.
*
* @return builder
*
*/
public Builder disabled(@Nullable Output disabled) {
$.disabled = disabled;
return this;
}
/**
* @param disabled Whether to disable the backup task. Valid values: `true`, `false`.
*
* @return builder
*
*/
public Builder disabled(Boolean disabled) {
return disabled(Output.of(disabled));
}
/**
* @param ossBackupPlanName The name of the backup plan. 1~64 characters, the backup plan name of each data source type in a single warehouse required to be unique.
*
* @return builder
*
*/
public Builder ossBackupPlanName(Output ossBackupPlanName) {
$.ossBackupPlanName = ossBackupPlanName;
return this;
}
/**
* @param ossBackupPlanName The name of the backup plan. 1~64 characters, the backup plan name of each data source type in a single warehouse required to be unique.
*
* @return builder
*
*/
public Builder ossBackupPlanName(String ossBackupPlanName) {
return ossBackupPlanName(Output.of(ossBackupPlanName));
}
/**
* @param prefix Backup prefix. Once specified, only objects with matching prefixes will be backed up.
*
* @return builder
*
*/
public Builder prefix(@Nullable Output prefix) {
$.prefix = prefix;
return this;
}
/**
* @param prefix Backup prefix. Once specified, only objects with matching prefixes will be backed up.
*
* @return builder
*
*/
public Builder prefix(String prefix) {
return prefix(Output.of(prefix));
}
/**
* @param retention Backup retention days, the minimum is 1.
*
* @return builder
*
*/
public Builder retention(Output retention) {
$.retention = retention;
return this;
}
/**
* @param retention Backup retention days, the minimum is 1.
*
* @return builder
*
*/
public Builder retention(String retention) {
return retention(Output.of(retention));
}
/**
* @param schedule Backup strategy. Optional format: `I|{startTime}|{interval}`. It means to execute a backup task every `{interval}` starting from `{startTime}`. The backup task for the elapsed time will not be compensated. If the last backup task has not completed yet, the next backup task will not be triggered.
* * `startTime` Backup start time, UNIX time seconds.
*
* @return builder
*
*/
public Builder schedule(Output schedule) {
$.schedule = schedule;
return this;
}
/**
* @param schedule Backup strategy. Optional format: `I|{startTime}|{interval}`. It means to execute a backup task every `{interval}` starting from `{startTime}`. The backup task for the elapsed time will not be compensated. If the last backup task has not completed yet, the next backup task will not be triggered.
* * `startTime` Backup start time, UNIX time seconds.
*
* @return builder
*
*/
public Builder schedule(String schedule) {
return schedule(Output.of(schedule));
}
/**
* @param vaultId The ID of backup vault.
*
* @return builder
*
*/
public Builder vaultId(Output vaultId) {
$.vaultId = vaultId;
return this;
}
/**
* @param vaultId The ID of backup vault.
*
* @return builder
*
*/
public Builder vaultId(String vaultId) {
return vaultId(Output.of(vaultId));
}
public OssBackupPlanArgs build() {
if ($.backupType == null) {
throw new MissingRequiredPropertyException("OssBackupPlanArgs", "backupType");
}
if ($.bucket == null) {
throw new MissingRequiredPropertyException("OssBackupPlanArgs", "bucket");
}
if ($.ossBackupPlanName == null) {
throw new MissingRequiredPropertyException("OssBackupPlanArgs", "ossBackupPlanName");
}
if ($.retention == null) {
throw new MissingRequiredPropertyException("OssBackupPlanArgs", "retention");
}
if ($.schedule == null) {
throw new MissingRequiredPropertyException("OssBackupPlanArgs", "schedule");
}
if ($.vaultId == null) {
throw new MissingRequiredPropertyException("OssBackupPlanArgs", "vaultId");
}
return $;
}
}
}