AccountPrivilegeArgs

data class AccountPrivilegeArgs(val accountName: Output<String>? = null, val accountPrivilege: Output<String>? = null, val dbClusterId: Output<String>? = null, val dbNames: Output<List<String>>? = null) : ConvertibleToJava<AccountPrivilegeArgs>

Provides a PolarDB account privilege resource and used to grant several database some access privilege. A database can be granted by multiple account.

NOTE: Available in v1.67.0+.

Example Usage

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.alicloud.AlicloudFunctions;
import com.pulumi.alicloud.inputs.GetZonesArgs;
import com.pulumi.alicloud.vpc.Network;
import com.pulumi.alicloud.vpc.NetworkArgs;
import com.pulumi.alicloud.vpc.Switch;
import com.pulumi.alicloud.vpc.SwitchArgs;
import com.pulumi.alicloud.polardb.Cluster;
import com.pulumi.alicloud.polardb.ClusterArgs;
import com.pulumi.alicloud.polardb.Database;
import com.pulumi.alicloud.polardb.DatabaseArgs;
import com.pulumi.alicloud.polardb.Account;
import com.pulumi.alicloud.polardb.AccountArgs;
import com.pulumi.alicloud.polardb.AccountPrivilege;
import com.pulumi.alicloud.polardb.AccountPrivilegeArgs;
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) {
final var config = ctx.config();
final var creation = config.get("creation").orElse("PolarDB");
final var name = config.get("name").orElse("dbaccountprivilegebasic");
final var defaultZones = AlicloudFunctions.getZones(GetZonesArgs.builder()
.availableResourceCreation(creation)
.build());
var defaultNetwork = new Network("defaultNetwork", NetworkArgs.builder()
.cidrBlock("172.16.0.0/16")
.build());
var defaultSwitch = new Switch("defaultSwitch", SwitchArgs.builder()
.vpcId(defaultNetwork.id())
.cidrBlock("172.16.0.0/24")
.zoneId(defaultZones.applyValue(getZonesResult -> getZonesResult.zones()[0].id()))
.build());
var cluster = new Cluster("cluster", ClusterArgs.builder()
.dbType("MySQL")
.dbVersion("8.0")
.payType("PostPaid")
.dbNodeClass("polar.mysql.x4.large")
.vswitchId(defaultSwitch.id())
.description(name)
.build());
var db = new Database("db", DatabaseArgs.builder()
.dbClusterId(cluster.id())
.dbName("tftestdatabase")
.build());
var account = new Account("account", AccountArgs.builder()
.dbClusterId(cluster.id())
.accountName("tftestnormal")
.accountPassword("Test12345")
.accountDescription(name)
.build());
var privilege = new AccountPrivilege("privilege", AccountPrivilegeArgs.builder()
.dbClusterId(cluster.id())
.accountName(account.accountName())
.accountPrivilege("ReadOnly")
.dbNames(db.dbName())
.build());
}
}

Import

PolarDB account privilege can be imported using the id, e.g.

$ pulumi import alicloud:polardb/accountPrivilege:AccountPrivilege example "pc-12345:tf_account:ReadOnly"

Constructors

Link copied to clipboard
fun AccountPrivilegeArgs(accountName: Output<String>? = null, accountPrivilege: Output<String>? = null, dbClusterId: Output<String>? = null, dbNames: Output<List<String>>? = null)

Functions

Link copied to clipboard
open override fun toJava(): AccountPrivilegeArgs

Properties

Link copied to clipboard
val accountName: Output<String>? = null

A specified account name.

Link copied to clipboard
val accountPrivilege: Output<String>? = null

The privilege of one account access database. Valid values: "ReadOnly", "ReadWrite", "DMLOnly", "DDLOnly" added since version v1.101.0. Default to "ReadOnly".

Link copied to clipboard
val dbClusterId: Output<String>? = null

The Id of cluster in which account belongs.

Link copied to clipboard
val dbNames: Output<List<String>>? = null

List of specified database name.