com.pulumi.gcp.looker.kotlin.InstanceArgs.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-gcp-kotlin Show documentation
Show all versions of pulumi-gcp-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.gcp.looker.kotlin
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.looker.InstanceArgs.builder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceAdminSettingsArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceAdminSettingsArgsBuilder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceCustomDomainArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceCustomDomainArgsBuilder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceDenyMaintenancePeriodArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceDenyMaintenancePeriodArgsBuilder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceEncryptionConfigArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceEncryptionConfigArgsBuilder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceMaintenanceWindowArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceMaintenanceWindowArgsBuilder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceOauthConfigArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceOauthConfigArgsBuilder
import com.pulumi.gcp.looker.kotlin.inputs.InstanceUserMetadataArgs
import com.pulumi.gcp.looker.kotlin.inputs.InstanceUserMetadataArgsBuilder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.jvm.JvmName
/**
* A Google Cloud Looker instance.
* To get more information about Instance, see:
* * [API documentation](https://cloud.google.com/looker/docs/reference/rest/v1/projects.locations.instances)
* * How-to Guides
* * [Create a Looker (Google Cloud core) instance](https://cloud.google.com/looker/docs/looker-core-instance-create)
* * [Configure a Looker (Google Cloud core) instance](https://cloud.google.com/looker/docs/looker-core-instance-setup)
* ## Example Usage
* ### Looker Instance Basic
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* const looker_instance = new gcp.looker.Instance("looker-instance", {
* name: "my-instance",
* platformEdition: "LOOKER_CORE_STANDARD_ANNUAL",
* region: "us-central1",
* oauthConfig: {
* clientId: "my-client-id",
* clientSecret: "my-client-secret",
* },
* });
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* looker_instance = gcp.looker.Instance("looker-instance",
* name="my-instance",
* platform_edition="LOOKER_CORE_STANDARD_ANNUAL",
* region="us-central1",
* oauth_config=gcp.looker.InstanceOauthConfigArgs(
* client_id="my-client-id",
* client_secret="my-client-secret",
* ))
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* return await Deployment.RunAsync(() =>
* {
* var looker_instance = new Gcp.Looker.Instance("looker-instance", new()
* {
* Name = "my-instance",
* PlatformEdition = "LOOKER_CORE_STANDARD_ANNUAL",
* Region = "us-central1",
* OauthConfig = new Gcp.Looker.Inputs.InstanceOauthConfigArgs
* {
* ClientId = "my-client-id",
* ClientSecret = "my-client-secret",
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/looker"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := looker.NewInstance(ctx, "looker-instance", &looker.InstanceArgs{
* Name: pulumi.String("my-instance"),
* PlatformEdition: pulumi.String("LOOKER_CORE_STANDARD_ANNUAL"),
* Region: pulumi.String("us-central1"),
* OauthConfig: &looker.InstanceOauthConfigArgs{
* ClientId: pulumi.String("my-client-id"),
* ClientSecret: pulumi.String("my-client-secret"),
* },
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.looker.Instance;
* import com.pulumi.gcp.looker.InstanceArgs;
* import com.pulumi.gcp.looker.inputs.InstanceOauthConfigArgs;
* 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 looker_instance = new Instance("looker-instance", InstanceArgs.builder()
* .name("my-instance")
* .platformEdition("LOOKER_CORE_STANDARD_ANNUAL")
* .region("us-central1")
* .oauthConfig(InstanceOauthConfigArgs.builder()
* .clientId("my-client-id")
* .clientSecret("my-client-secret")
* .build())
* .build());
* }
* }
* ```
* ```yaml
* resources:
* looker-instance:
* type: gcp:looker:Instance
* properties:
* name: my-instance
* platformEdition: LOOKER_CORE_STANDARD_ANNUAL
* region: us-central1
* oauthConfig:
* clientId: my-client-id
* clientSecret: my-client-secret
* ```
*
* ### Looker Instance Full
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* const looker_instance = new gcp.looker.Instance("looker-instance", {
* name: "my-instance",
* platformEdition: "LOOKER_CORE_STANDARD_ANNUAL",
* region: "us-central1",
* publicIpEnabled: true,
* adminSettings: {
* allowedEmailDomains: ["google.com"],
* },
* maintenanceWindow: {
* dayOfWeek: "THURSDAY",
* startTime: {
* hours: 22,
* minutes: 0,
* seconds: 0,
* nanos: 0,
* },
* },
* denyMaintenancePeriod: {
* startDate: {
* year: 2050,
* month: 1,
* day: 1,
* },
* endDate: {
* year: 2050,
* month: 2,
* day: 1,
* },
* time: {
* hours: 10,
* minutes: 0,
* seconds: 0,
* nanos: 0,
* },
* },
* oauthConfig: {
* clientId: "my-client-id",
* clientSecret: "my-client-secret",
* },
* });
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* looker_instance = gcp.looker.Instance("looker-instance",
* name="my-instance",
* platform_edition="LOOKER_CORE_STANDARD_ANNUAL",
* region="us-central1",
* public_ip_enabled=True,
* admin_settings=gcp.looker.InstanceAdminSettingsArgs(
* allowed_email_domains=["google.com"],
* ),
* maintenance_window=gcp.looker.InstanceMaintenanceWindowArgs(
* day_of_week="THURSDAY",
* start_time=gcp.looker.InstanceMaintenanceWindowStartTimeArgs(
* hours=22,
* minutes=0,
* seconds=0,
* nanos=0,
* ),
* ),
* deny_maintenance_period=gcp.looker.InstanceDenyMaintenancePeriodArgs(
* start_date=gcp.looker.InstanceDenyMaintenancePeriodStartDateArgs(
* year=2050,
* month=1,
* day=1,
* ),
* end_date=gcp.looker.InstanceDenyMaintenancePeriodEndDateArgs(
* year=2050,
* month=2,
* day=1,
* ),
* time=gcp.looker.InstanceDenyMaintenancePeriodTimeArgs(
* hours=10,
* minutes=0,
* seconds=0,
* nanos=0,
* ),
* ),
* oauth_config=gcp.looker.InstanceOauthConfigArgs(
* client_id="my-client-id",
* client_secret="my-client-secret",
* ))
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* return await Deployment.RunAsync(() =>
* {
* var looker_instance = new Gcp.Looker.Instance("looker-instance", new()
* {
* Name = "my-instance",
* PlatformEdition = "LOOKER_CORE_STANDARD_ANNUAL",
* Region = "us-central1",
* PublicIpEnabled = true,
* AdminSettings = new Gcp.Looker.Inputs.InstanceAdminSettingsArgs
* {
* AllowedEmailDomains = new[]
* {
* "google.com",
* },
* },
* MaintenanceWindow = new Gcp.Looker.Inputs.InstanceMaintenanceWindowArgs
* {
* DayOfWeek = "THURSDAY",
* StartTime = new Gcp.Looker.Inputs.InstanceMaintenanceWindowStartTimeArgs
* {
* Hours = 22,
* Minutes = 0,
* Seconds = 0,
* Nanos = 0,
* },
* },
* DenyMaintenancePeriod = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodArgs
* {
* StartDate = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodStartDateArgs
* {
* Year = 2050,
* Month = 1,
* Day = 1,
* },
* EndDate = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodEndDateArgs
* {
* Year = 2050,
* Month = 2,
* Day = 1,
* },
* Time = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodTimeArgs
* {
* Hours = 10,
* Minutes = 0,
* Seconds = 0,
* Nanos = 0,
* },
* },
* OauthConfig = new Gcp.Looker.Inputs.InstanceOauthConfigArgs
* {
* ClientId = "my-client-id",
* ClientSecret = "my-client-secret",
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/looker"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := looker.NewInstance(ctx, "looker-instance", &looker.InstanceArgs{
* Name: pulumi.String("my-instance"),
* PlatformEdition: pulumi.String("LOOKER_CORE_STANDARD_ANNUAL"),
* Region: pulumi.String("us-central1"),
* PublicIpEnabled: pulumi.Bool(true),
* AdminSettings: &looker.InstanceAdminSettingsArgs{
* AllowedEmailDomains: pulumi.StringArray{
* pulumi.String("google.com"),
* },
* },
* MaintenanceWindow: &looker.InstanceMaintenanceWindowArgs{
* DayOfWeek: pulumi.String("THURSDAY"),
* StartTime: &looker.InstanceMaintenanceWindowStartTimeArgs{
* Hours: pulumi.Int(22),
* Minutes: pulumi.Int(0),
* Seconds: pulumi.Int(0),
* Nanos: pulumi.Int(0),
* },
* },
* DenyMaintenancePeriod: &looker.InstanceDenyMaintenancePeriodArgs{
* StartDate: &looker.InstanceDenyMaintenancePeriodStartDateArgs{
* Year: pulumi.Int(2050),
* Month: pulumi.Int(1),
* Day: pulumi.Int(1),
* },
* EndDate: &looker.InstanceDenyMaintenancePeriodEndDateArgs{
* Year: pulumi.Int(2050),
* Month: pulumi.Int(2),
* Day: pulumi.Int(1),
* },
* Time: &looker.InstanceDenyMaintenancePeriodTimeArgs{
* Hours: pulumi.Int(10),
* Minutes: pulumi.Int(0),
* Seconds: pulumi.Int(0),
* Nanos: pulumi.Int(0),
* },
* },
* OauthConfig: &looker.InstanceOauthConfigArgs{
* ClientId: pulumi.String("my-client-id"),
* ClientSecret: pulumi.String("my-client-secret"),
* },
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.looker.Instance;
* import com.pulumi.gcp.looker.InstanceArgs;
* import com.pulumi.gcp.looker.inputs.InstanceAdminSettingsArgs;
* import com.pulumi.gcp.looker.inputs.InstanceMaintenanceWindowArgs;
* import com.pulumi.gcp.looker.inputs.InstanceMaintenanceWindowStartTimeArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodStartDateArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodEndDateArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodTimeArgs;
* import com.pulumi.gcp.looker.inputs.InstanceOauthConfigArgs;
* 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 looker_instance = new Instance("looker-instance", InstanceArgs.builder()
* .name("my-instance")
* .platformEdition("LOOKER_CORE_STANDARD_ANNUAL")
* .region("us-central1")
* .publicIpEnabled(true)
* .adminSettings(InstanceAdminSettingsArgs.builder()
* .allowedEmailDomains("google.com")
* .build())
* .maintenanceWindow(InstanceMaintenanceWindowArgs.builder()
* .dayOfWeek("THURSDAY")
* .startTime(InstanceMaintenanceWindowStartTimeArgs.builder()
* .hours(22)
* .minutes(0)
* .seconds(0)
* .nanos(0)
* .build())
* .build())
* .denyMaintenancePeriod(InstanceDenyMaintenancePeriodArgs.builder()
* .startDate(InstanceDenyMaintenancePeriodStartDateArgs.builder()
* .year(2050)
* .month(1)
* .day(1)
* .build())
* .endDate(InstanceDenyMaintenancePeriodEndDateArgs.builder()
* .year(2050)
* .month(2)
* .day(1)
* .build())
* .time(InstanceDenyMaintenancePeriodTimeArgs.builder()
* .hours(10)
* .minutes(0)
* .seconds(0)
* .nanos(0)
* .build())
* .build())
* .oauthConfig(InstanceOauthConfigArgs.builder()
* .clientId("my-client-id")
* .clientSecret("my-client-secret")
* .build())
* .build());
* }
* }
* ```
* ```yaml
* resources:
* looker-instance:
* type: gcp:looker:Instance
* properties:
* name: my-instance
* platformEdition: LOOKER_CORE_STANDARD_ANNUAL
* region: us-central1
* publicIpEnabled: true
* adminSettings:
* allowedEmailDomains:
* - google.com
* maintenanceWindow:
* dayOfWeek: THURSDAY
* startTime:
* hours: 22
* minutes: 0
* seconds: 0
* nanos: 0
* denyMaintenancePeriod:
* startDate:
* year: 2050
* month: 1
* day: 1
* endDate:
* year: 2050
* month: 2
* day: 1
* time:
* hours: 10
* minutes: 0
* seconds: 0
* nanos: 0
* oauthConfig:
* clientId: my-client-id
* clientSecret: my-client-secret
* ```
*
* ### Looker Instance Enterprise Full
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* const lookerNetwork = new gcp.compute.Network("looker_network", {name: "looker-network"});
* const lookerRange = new gcp.compute.GlobalAddress("looker_range", {
* name: "looker-range",
* purpose: "VPC_PEERING",
* addressType: "INTERNAL",
* prefixLength: 20,
* network: lookerNetwork.id,
* });
* const looker_instance = new gcp.looker.Instance("looker-instance", {
* name: "my-instance",
* platformEdition: "LOOKER_CORE_ENTERPRISE_ANNUAL",
* region: "us-central1",
* privateIpEnabled: true,
* publicIpEnabled: false,
* reservedRange: lookerRange.name,
* consumerNetwork: lookerNetwork.id,
* adminSettings: {
* allowedEmailDomains: ["google.com"],
* },
* encryptionConfig: {
* kmsKeyName: "looker-kms-key",
* },
* maintenanceWindow: {
* dayOfWeek: "THURSDAY",
* startTime: {
* hours: 22,
* minutes: 0,
* seconds: 0,
* nanos: 0,
* },
* },
* denyMaintenancePeriod: {
* startDate: {
* year: 2050,
* month: 1,
* day: 1,
* },
* endDate: {
* year: 2050,
* month: 2,
* day: 1,
* },
* time: {
* hours: 10,
* minutes: 0,
* seconds: 0,
* nanos: 0,
* },
* },
* oauthConfig: {
* clientId: "my-client-id",
* clientSecret: "my-client-secret",
* },
* });
* const lookerVpcConnection = new gcp.servicenetworking.Connection("looker_vpc_connection", {
* network: lookerNetwork.id,
* service: "servicenetworking.googleapis.com",
* reservedPeeringRanges: [lookerRange.name],
* });
* const project = gcp.organizations.getProject({});
* const cryptoKey = new gcp.kms.CryptoKeyIAMMember("crypto_key", {
* cryptoKeyId: "looker-kms-key",
* role: "roles/cloudkms.cryptoKeyEncrypterDecrypter",
* member: project.then(project => `serviceAccount:service-${project.number}@gcp-sa-looker.iam.gserviceaccount.com`),
* });
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* looker_network = gcp.compute.Network("looker_network", name="looker-network")
* looker_range = gcp.compute.GlobalAddress("looker_range",
* name="looker-range",
* purpose="VPC_PEERING",
* address_type="INTERNAL",
* prefix_length=20,
* network=looker_network.id)
* looker_instance = gcp.looker.Instance("looker-instance",
* name="my-instance",
* platform_edition="LOOKER_CORE_ENTERPRISE_ANNUAL",
* region="us-central1",
* private_ip_enabled=True,
* public_ip_enabled=False,
* reserved_range=looker_range.name,
* consumer_network=looker_network.id,
* admin_settings=gcp.looker.InstanceAdminSettingsArgs(
* allowed_email_domains=["google.com"],
* ),
* encryption_config=gcp.looker.InstanceEncryptionConfigArgs(
* kms_key_name="looker-kms-key",
* ),
* maintenance_window=gcp.looker.InstanceMaintenanceWindowArgs(
* day_of_week="THURSDAY",
* start_time=gcp.looker.InstanceMaintenanceWindowStartTimeArgs(
* hours=22,
* minutes=0,
* seconds=0,
* nanos=0,
* ),
* ),
* deny_maintenance_period=gcp.looker.InstanceDenyMaintenancePeriodArgs(
* start_date=gcp.looker.InstanceDenyMaintenancePeriodStartDateArgs(
* year=2050,
* month=1,
* day=1,
* ),
* end_date=gcp.looker.InstanceDenyMaintenancePeriodEndDateArgs(
* year=2050,
* month=2,
* day=1,
* ),
* time=gcp.looker.InstanceDenyMaintenancePeriodTimeArgs(
* hours=10,
* minutes=0,
* seconds=0,
* nanos=0,
* ),
* ),
* oauth_config=gcp.looker.InstanceOauthConfigArgs(
* client_id="my-client-id",
* client_secret="my-client-secret",
* ))
* looker_vpc_connection = gcp.servicenetworking.Connection("looker_vpc_connection",
* network=looker_network.id,
* service="servicenetworking.googleapis.com",
* reserved_peering_ranges=[looker_range.name])
* project = gcp.organizations.get_project()
* crypto_key = gcp.kms.CryptoKeyIAMMember("crypto_key",
* crypto_key_id="looker-kms-key",
* role="roles/cloudkms.cryptoKeyEncrypterDecrypter",
* member=f"serviceAccount:service-{project.number}@gcp-sa-looker.iam.gserviceaccount.com")
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* return await Deployment.RunAsync(() =>
* {
* var lookerNetwork = new Gcp.Compute.Network("looker_network", new()
* {
* Name = "looker-network",
* });
* var lookerRange = new Gcp.Compute.GlobalAddress("looker_range", new()
* {
* Name = "looker-range",
* Purpose = "VPC_PEERING",
* AddressType = "INTERNAL",
* PrefixLength = 20,
* Network = lookerNetwork.Id,
* });
* var looker_instance = new Gcp.Looker.Instance("looker-instance", new()
* {
* Name = "my-instance",
* PlatformEdition = "LOOKER_CORE_ENTERPRISE_ANNUAL",
* Region = "us-central1",
* PrivateIpEnabled = true,
* PublicIpEnabled = false,
* ReservedRange = lookerRange.Name,
* ConsumerNetwork = lookerNetwork.Id,
* AdminSettings = new Gcp.Looker.Inputs.InstanceAdminSettingsArgs
* {
* AllowedEmailDomains = new[]
* {
* "google.com",
* },
* },
* EncryptionConfig = new Gcp.Looker.Inputs.InstanceEncryptionConfigArgs
* {
* KmsKeyName = "looker-kms-key",
* },
* MaintenanceWindow = new Gcp.Looker.Inputs.InstanceMaintenanceWindowArgs
* {
* DayOfWeek = "THURSDAY",
* StartTime = new Gcp.Looker.Inputs.InstanceMaintenanceWindowStartTimeArgs
* {
* Hours = 22,
* Minutes = 0,
* Seconds = 0,
* Nanos = 0,
* },
* },
* DenyMaintenancePeriod = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodArgs
* {
* StartDate = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodStartDateArgs
* {
* Year = 2050,
* Month = 1,
* Day = 1,
* },
* EndDate = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodEndDateArgs
* {
* Year = 2050,
* Month = 2,
* Day = 1,
* },
* Time = new Gcp.Looker.Inputs.InstanceDenyMaintenancePeriodTimeArgs
* {
* Hours = 10,
* Minutes = 0,
* Seconds = 0,
* Nanos = 0,
* },
* },
* OauthConfig = new Gcp.Looker.Inputs.InstanceOauthConfigArgs
* {
* ClientId = "my-client-id",
* ClientSecret = "my-client-secret",
* },
* });
* var lookerVpcConnection = new Gcp.ServiceNetworking.Connection("looker_vpc_connection", new()
* {
* Network = lookerNetwork.Id,
* Service = "servicenetworking.googleapis.com",
* ReservedPeeringRanges = new[]
* {
* lookerRange.Name,
* },
* });
* var project = Gcp.Organizations.GetProject.Invoke();
* var cryptoKey = new Gcp.Kms.CryptoKeyIAMMember("crypto_key", new()
* {
* CryptoKeyId = "looker-kms-key",
* Role = "roles/cloudkms.cryptoKeyEncrypterDecrypter",
* Member = $"serviceAccount:service-{project.Apply(getProjectResult => getProjectResult.Number)}@gcp-sa-looker.iam.gserviceaccount.com",
* });
* });
* ```
* ```go
* package main
* import (
* "fmt"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/kms"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/looker"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/organizations"
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/servicenetworking"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* lookerNetwork, err := compute.NewNetwork(ctx, "looker_network", &compute.NetworkArgs{
* Name: pulumi.String("looker-network"),
* })
* if err != nil {
* return err
* }
* lookerRange, err := compute.NewGlobalAddress(ctx, "looker_range", &compute.GlobalAddressArgs{
* Name: pulumi.String("looker-range"),
* Purpose: pulumi.String("VPC_PEERING"),
* AddressType: pulumi.String("INTERNAL"),
* PrefixLength: pulumi.Int(20),
* Network: lookerNetwork.ID(),
* })
* if err != nil {
* return err
* }
* _, err = looker.NewInstance(ctx, "looker-instance", &looker.InstanceArgs{
* Name: pulumi.String("my-instance"),
* PlatformEdition: pulumi.String("LOOKER_CORE_ENTERPRISE_ANNUAL"),
* Region: pulumi.String("us-central1"),
* PrivateIpEnabled: pulumi.Bool(true),
* PublicIpEnabled: pulumi.Bool(false),
* ReservedRange: lookerRange.Name,
* ConsumerNetwork: lookerNetwork.ID(),
* AdminSettings: &looker.InstanceAdminSettingsArgs{
* AllowedEmailDomains: pulumi.StringArray{
* pulumi.String("google.com"),
* },
* },
* EncryptionConfig: &looker.InstanceEncryptionConfigArgs{
* KmsKeyName: pulumi.String("looker-kms-key"),
* },
* MaintenanceWindow: &looker.InstanceMaintenanceWindowArgs{
* DayOfWeek: pulumi.String("THURSDAY"),
* StartTime: &looker.InstanceMaintenanceWindowStartTimeArgs{
* Hours: pulumi.Int(22),
* Minutes: pulumi.Int(0),
* Seconds: pulumi.Int(0),
* Nanos: pulumi.Int(0),
* },
* },
* DenyMaintenancePeriod: &looker.InstanceDenyMaintenancePeriodArgs{
* StartDate: &looker.InstanceDenyMaintenancePeriodStartDateArgs{
* Year: pulumi.Int(2050),
* Month: pulumi.Int(1),
* Day: pulumi.Int(1),
* },
* EndDate: &looker.InstanceDenyMaintenancePeriodEndDateArgs{
* Year: pulumi.Int(2050),
* Month: pulumi.Int(2),
* Day: pulumi.Int(1),
* },
* Time: &looker.InstanceDenyMaintenancePeriodTimeArgs{
* Hours: pulumi.Int(10),
* Minutes: pulumi.Int(0),
* Seconds: pulumi.Int(0),
* Nanos: pulumi.Int(0),
* },
* },
* OauthConfig: &looker.InstanceOauthConfigArgs{
* ClientId: pulumi.String("my-client-id"),
* ClientSecret: pulumi.String("my-client-secret"),
* },
* })
* if err != nil {
* return err
* }
* _, err = servicenetworking.NewConnection(ctx, "looker_vpc_connection", &servicenetworking.ConnectionArgs{
* Network: lookerNetwork.ID(),
* Service: pulumi.String("servicenetworking.googleapis.com"),
* ReservedPeeringRanges: pulumi.StringArray{
* lookerRange.Name,
* },
* })
* if err != nil {
* return err
* }
* project, err := organizations.LookupProject(ctx, nil, nil)
* if err != nil {
* return err
* }
* _, err = kms.NewCryptoKeyIAMMember(ctx, "crypto_key", &kms.CryptoKeyIAMMemberArgs{
* CryptoKeyId: pulumi.String("looker-kms-key"),
* Role: pulumi.String("roles/cloudkms.cryptoKeyEncrypterDecrypter"),
* Member: pulumi.String(fmt.Sprintf("serviceAccount:service-%[email protected]", project.Number)),
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.compute.Network;
* import com.pulumi.gcp.compute.NetworkArgs;
* import com.pulumi.gcp.compute.GlobalAddress;
* import com.pulumi.gcp.compute.GlobalAddressArgs;
* import com.pulumi.gcp.looker.Instance;
* import com.pulumi.gcp.looker.InstanceArgs;
* import com.pulumi.gcp.looker.inputs.InstanceAdminSettingsArgs;
* import com.pulumi.gcp.looker.inputs.InstanceEncryptionConfigArgs;
* import com.pulumi.gcp.looker.inputs.InstanceMaintenanceWindowArgs;
* import com.pulumi.gcp.looker.inputs.InstanceMaintenanceWindowStartTimeArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodStartDateArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodEndDateArgs;
* import com.pulumi.gcp.looker.inputs.InstanceDenyMaintenancePeriodTimeArgs;
* import com.pulumi.gcp.looker.inputs.InstanceOauthConfigArgs;
* import com.pulumi.gcp.servicenetworking.Connection;
* import com.pulumi.gcp.servicenetworking.ConnectionArgs;
* import com.pulumi.gcp.organizations.OrganizationsFunctions;
* import com.pulumi.gcp.organizations.inputs.GetProjectArgs;
* import com.pulumi.gcp.kms.CryptoKeyIAMMember;
* import com.pulumi.gcp.kms.CryptoKeyIAMMemberArgs;
* 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 lookerNetwork = new Network("lookerNetwork", NetworkArgs.builder()
* .name("looker-network")
* .build());
* var lookerRange = new GlobalAddress("lookerRange", GlobalAddressArgs.builder()
* .name("looker-range")
* .purpose("VPC_PEERING")
* .addressType("INTERNAL")
* .prefixLength(20)
* .network(lookerNetwork.id())
* .build());
* var looker_instance = new Instance("looker-instance", InstanceArgs.builder()
* .name("my-instance")
* .platformEdition("LOOKER_CORE_ENTERPRISE_ANNUAL")
* .region("us-central1")
* .privateIpEnabled(true)
* .publicIpEnabled(false)
* .reservedRange(lookerRange.name())
* .consumerNetwork(lookerNetwork.id())
* .adminSettings(InstanceAdminSettingsArgs.builder()
* .allowedEmailDomains("google.com")
* .build())
* .encryptionConfig(InstanceEncryptionConfigArgs.builder()
* .kmsKeyName("looker-kms-key")
* .build())
* .maintenanceWindow(InstanceMaintenanceWindowArgs.builder()
* .dayOfWeek("THURSDAY")
* .startTime(InstanceMaintenanceWindowStartTimeArgs.builder()
* .hours(22)
* .minutes(0)
* .seconds(0)
* .nanos(0)
* .build())
* .build())
* .denyMaintenancePeriod(InstanceDenyMaintenancePeriodArgs.builder()
* .startDate(InstanceDenyMaintenancePeriodStartDateArgs.builder()
* .year(2050)
* .month(1)
* .day(1)
* .build())
* .endDate(InstanceDenyMaintenancePeriodEndDateArgs.builder()
* .year(2050)
* .month(2)
* .day(1)
* .build())
* .time(InstanceDenyMaintenancePeriodTimeArgs.builder()
* .hours(10)
* .minutes(0)
* .seconds(0)
* .nanos(0)
* .build())
* .build())
* .oauthConfig(InstanceOauthConfigArgs.builder()
* .clientId("my-client-id")
* .clientSecret("my-client-secret")
* .build())
* .build());
* var lookerVpcConnection = new Connection("lookerVpcConnection", ConnectionArgs.builder()
* .network(lookerNetwork.id())
* .service("servicenetworking.googleapis.com")
* .reservedPeeringRanges(lookerRange.name())
* .build());
* final var project = OrganizationsFunctions.getProject();
* var cryptoKey = new CryptoKeyIAMMember("cryptoKey", CryptoKeyIAMMemberArgs.builder()
* .cryptoKeyId("looker-kms-key")
* .role("roles/cloudkms.cryptoKeyEncrypterDecrypter")
* .member(String.format("serviceAccount:service-%[email protected]", project.applyValue(getProjectResult -> getProjectResult.number())))
* .build());
* }
* }
* ```
* ```yaml
* resources:
* looker-instance:
* type: gcp:looker:Instance
* properties:
* name: my-instance
* platformEdition: LOOKER_CORE_ENTERPRISE_ANNUAL
* region: us-central1
* privateIpEnabled: true
* publicIpEnabled: false
* reservedRange: ${lookerRange.name}
* consumerNetwork: ${lookerNetwork.id}
* adminSettings:
* allowedEmailDomains:
* - google.com
* encryptionConfig:
* kmsKeyName: looker-kms-key
* maintenanceWindow:
* dayOfWeek: THURSDAY
* startTime:
* hours: 22
* minutes: 0
* seconds: 0
* nanos: 0
* denyMaintenancePeriod:
* startDate:
* year: 2050
* month: 1
* day: 1
* endDate:
* year: 2050
* month: 2
* day: 1
* time:
* hours: 10
* minutes: 0
* seconds: 0
* nanos: 0
* oauthConfig:
* clientId: my-client-id
* clientSecret: my-client-secret
* lookerVpcConnection:
* type: gcp:servicenetworking:Connection
* name: looker_vpc_connection
* properties:
* network: ${lookerNetwork.id}
* service: servicenetworking.googleapis.com
* reservedPeeringRanges:
* - ${lookerRange.name}
* lookerRange:
* type: gcp:compute:GlobalAddress
* name: looker_range
* properties:
* name: looker-range
* purpose: VPC_PEERING
* addressType: INTERNAL
* prefixLength: 20
* network: ${lookerNetwork.id}
* lookerNetwork:
* type: gcp:compute:Network
* name: looker_network
* properties:
* name: looker-network
* cryptoKey:
* type: gcp:kms:CryptoKeyIAMMember
* name: crypto_key
* properties:
* cryptoKeyId: looker-kms-key
* role: roles/cloudkms.cryptoKeyEncrypterDecrypter
* member: serviceAccount:service-${project.number}@gcp-sa-looker.iam.gserviceaccount.com
* variables:
* project:
* fn::invoke:
* Function: gcp:organizations:getProject
* Arguments: {}
* ```
*
* ### Looker Instance Custom Domain
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gcp from "@pulumi/gcp";
* const looker_instance = new gcp.looker.Instance("looker-instance", {
* name: "my-instance",
* platformEdition: "LOOKER_CORE_STANDARD_ANNUAL",
* region: "us-central1",
* oauthConfig: {
* clientId: "my-client-id",
* clientSecret: "my-client-secret",
* },
* customDomain: {
* domain: "my-custom-domain.com",
* },
* });
* ```
* ```python
* import pulumi
* import pulumi_gcp as gcp
* looker_instance = gcp.looker.Instance("looker-instance",
* name="my-instance",
* platform_edition="LOOKER_CORE_STANDARD_ANNUAL",
* region="us-central1",
* oauth_config=gcp.looker.InstanceOauthConfigArgs(
* client_id="my-client-id",
* client_secret="my-client-secret",
* ),
* custom_domain=gcp.looker.InstanceCustomDomainArgs(
* domain="my-custom-domain.com",
* ))
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Gcp = Pulumi.Gcp;
* return await Deployment.RunAsync(() =>
* {
* var looker_instance = new Gcp.Looker.Instance("looker-instance", new()
* {
* Name = "my-instance",
* PlatformEdition = "LOOKER_CORE_STANDARD_ANNUAL",
* Region = "us-central1",
* OauthConfig = new Gcp.Looker.Inputs.InstanceOauthConfigArgs
* {
* ClientId = "my-client-id",
* ClientSecret = "my-client-secret",
* },
* CustomDomain = new Gcp.Looker.Inputs.InstanceCustomDomainArgs
* {
* Domain = "my-custom-domain.com",
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/looker"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := looker.NewInstance(ctx, "looker-instance", &looker.InstanceArgs{
* Name: pulumi.String("my-instance"),
* PlatformEdition: pulumi.String("LOOKER_CORE_STANDARD_ANNUAL"),
* Region: pulumi.String("us-central1"),
* OauthConfig: &looker.InstanceOauthConfigArgs{
* ClientId: pulumi.String("my-client-id"),
* ClientSecret: pulumi.String("my-client-secret"),
* },
* CustomDomain: &looker.InstanceCustomDomainArgs{
* Domain: pulumi.String("my-custom-domain.com"),
* },
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gcp.looker.Instance;
* import com.pulumi.gcp.looker.InstanceArgs;
* import com.pulumi.gcp.looker.inputs.InstanceOauthConfigArgs;
* import com.pulumi.gcp.looker.inputs.InstanceCustomDomainArgs;
* 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 looker_instance = new Instance("looker-instance", InstanceArgs.builder()
* .name("my-instance")
* .platformEdition("LOOKER_CORE_STANDARD_ANNUAL")
* .region("us-central1")
* .oauthConfig(InstanceOauthConfigArgs.builder()
* .clientId("my-client-id")
* .clientSecret("my-client-secret")
* .build())
* .customDomain(InstanceCustomDomainArgs.builder()
* .domain("my-custom-domain.com")
* .build())
* .build());
* }
* }
* ```
* ```yaml
* resources:
* looker-instance:
* type: gcp:looker:Instance
* properties:
* name: my-instance
* platformEdition: LOOKER_CORE_STANDARD_ANNUAL
* region: us-central1
* oauthConfig:
* clientId: my-client-id
* clientSecret: my-client-secret
* customDomain:
* domain: my-custom-domain.com
* ```
*
* ## Import
* Instance can be imported using any of these accepted formats:
* * `projects/{{project}}/locations/{{region}}/instances/{{name}}`
* * `{{project}}/{{region}}/{{name}}`
* * `{{region}}/{{name}}`
* * `{{name}}`
* When using the `pulumi import` command, Instance can be imported using one of the formats above. For example:
* ```sh
* $ pulumi import gcp:looker/instance:Instance default projects/{{project}}/locations/{{region}}/instances/{{name}}
* ```
* ```sh
* $ pulumi import gcp:looker/instance:Instance default {{project}}/{{region}}/{{name}}
* ```
* ```sh
* $ pulumi import gcp:looker/instance:Instance default {{region}}/{{name}}
* ```
* ```sh
* $ pulumi import gcp:looker/instance:Instance default {{name}}
* ```
* @property adminSettings Looker instance Admin settings.
* Structure is documented below.
* @property consumerNetwork Network name in the consumer project in the format of: projects/{project}/global/networks/{network}
* Note that the consumer network may be in a different GCP project than the consumer
* project that is hosting the Looker Instance.
* @property customDomain Custom domain settings for a Looker instance.
* Structure is documented below.
* @property denyMaintenancePeriod Maintenance denial period for this instance.
* You must allow at least 14 days of maintenance availability
* between any two deny maintenance periods.
* Structure is documented below.
* @property encryptionConfig Looker instance encryption settings.
* Structure is documented below.
* @property maintenanceWindow Maintenance window for an instance.
* Maintenance of your instance takes place once a month, and will require
* your instance to be restarted during updates, which will temporarily
* disrupt service.
* Structure is documented below.
* @property name The ID of the instance or a fully qualified identifier for the instance.
* - - -
* @property oauthConfig Looker Instance OAuth login settings.
* Structure is documented below.
* @property platformEdition Platform editions for a Looker instance. Each edition maps to a set of instance features, like its size. Must be one of these values:
* - LOOKER_CORE_TRIAL: trial instance (Currently Unavailable)
* - LOOKER_CORE_STANDARD: pay as you go standard instance (Currently Unavailable)
* - LOOKER_CORE_STANDARD_ANNUAL: subscription standard instance
* - LOOKER_CORE_ENTERPRISE_ANNUAL: subscription enterprise instance
* - LOOKER_CORE_EMBED_ANNUAL: subscription embed instance
* Default value is `LOOKER_CORE_TRIAL`.
* Possible values are: `LOOKER_CORE_TRIAL`, `LOOKER_CORE_STANDARD`, `LOOKER_CORE_STANDARD_ANNUAL`, `LOOKER_CORE_ENTERPRISE_ANNUAL`, `LOOKER_CORE_EMBED_ANNUAL`.
* @property privateIpEnabled Whether private IP is enabled on the Looker instance.
* @property project The ID of the project in which the resource belongs.
* If it is not provided, the provider project is used.
* @property publicIpEnabled Whether public IP is enabled on the Looker instance.
* @property region The name of the Looker region of the instance.
* @property reservedRange Name of a reserved IP address range within the consumer network, to be used for
* private service access connection. User may or may not specify this in a request.
* @property userMetadata Metadata about users for a Looker instance.
* These settings are only available when platform edition LOOKER_CORE_STANDARD is set.
* There are ten Standard and two Developer users included in the cost of the product.
* You can allocate additional Standard, Viewer, and Developer users for this instance.
* It is an optional step and can be modified later.
* With the Standard edition of Looker (Google Cloud core), you can provision up to 50
* total users, distributed across Viewer, Standard, and Developer.
* Structure is documented below.
*/
public data class InstanceArgs(
public val adminSettings: Output? = null,
public val consumerNetwork: Output? = null,
public val customDomain: Output? = null,
public val denyMaintenancePeriod: Output? = null,
public val encryptionConfig: Output? = null,
public val maintenanceWindow: Output? = null,
public val name: Output? = null,
public val oauthConfig: Output? = null,
public val platformEdition: Output? = null,
public val privateIpEnabled: Output? = null,
public val project: Output? = null,
public val publicIpEnabled: Output? = null,
public val region: Output? = null,
public val reservedRange: Output? = null,
public val userMetadata: Output? = null,
) : ConvertibleToJava {
override fun toJava(): com.pulumi.gcp.looker.InstanceArgs =
com.pulumi.gcp.looker.InstanceArgs.builder()
.adminSettings(adminSettings?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.consumerNetwork(consumerNetwork?.applyValue({ args0 -> args0 }))
.customDomain(customDomain?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.denyMaintenancePeriod(
denyMaintenancePeriod?.applyValue({ args0 ->
args0.let({ args0 ->
args0.toJava()
})
}),
)
.encryptionConfig(encryptionConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.maintenanceWindow(maintenanceWindow?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.name(name?.applyValue({ args0 -> args0 }))
.oauthConfig(oauthConfig?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) }))
.platformEdition(platformEdition?.applyValue({ args0 -> args0 }))
.privateIpEnabled(privateIpEnabled?.applyValue({ args0 -> args0 }))
.project(project?.applyValue({ args0 -> args0 }))
.publicIpEnabled(publicIpEnabled?.applyValue({ args0 -> args0 }))
.region(region?.applyValue({ args0 -> args0 }))
.reservedRange(reservedRange?.applyValue({ args0 -> args0 }))
.userMetadata(userMetadata?.applyValue({ args0 -> args0.let({ args0 -> args0.toJava() }) })).build()
}
/**
* Builder for [InstanceArgs].
*/
@PulumiTagMarker
public class InstanceArgsBuilder internal constructor() {
private var adminSettings: Output? = null
private var consumerNetwork: Output? = null
private var customDomain: Output? = null
private var denyMaintenancePeriod: Output? = null
private var encryptionConfig: Output? = null
private var maintenanceWindow: Output? = null
private var name: Output? = null
private var oauthConfig: Output? = null
private var platformEdition: Output? = null
private var privateIpEnabled: Output? = null
private var project: Output? = null
private var publicIpEnabled: Output? = null
private var region: Output? = null
private var reservedRange: Output? = null
private var userMetadata: Output? = null
/**
* @param value Looker instance Admin settings.
* Structure is documented below.
*/
@JvmName("ibylcsbqsecwgeip")
public suspend fun adminSettings(`value`: Output) {
this.adminSettings = value
}
/**
* @param value Network name in the consumer project in the format of: projects/{project}/global/networks/{network}
* Note that the consumer network may be in a different GCP project than the consumer
* project that is hosting the Looker Instance.
*/
@JvmName("sqtfqqjlxfmmexaw")
public suspend fun consumerNetwork(`value`: Output) {
this.consumerNetwork = value
}
/**
* @param value Custom domain settings for a Looker instance.
* Structure is documented below.
*/
@JvmName("eygamqdgnsttmiua")
public suspend fun customDomain(`value`: Output) {
this.customDomain = value
}
/**
* @param value Maintenance denial period for this instance.
* You must allow at least 14 days of maintenance availability
* between any two deny maintenance periods.
* Structure is documented below.
*/
@JvmName("nsxjydehhkghxrno")
public suspend fun denyMaintenancePeriod(`value`: Output) {
this.denyMaintenancePeriod = value
}
/**
* @param value Looker instance encryption settings.
* Structure is documented below.
*/
@JvmName("jtpiptqpjvouahks")
public suspend fun encryptionConfig(`value`: Output) {
this.encryptionConfig = value
}
/**
* @param value Maintenance window for an instance.
* Maintenance of your instance takes place once a month, and will require
* your instance to be restarted during updates, which will temporarily
* disrupt service.
* Structure is documented below.
*/
@JvmName("ixybiikxpndeasho")
public suspend fun maintenanceWindow(`value`: Output) {
this.maintenanceWindow = value
}
/**
* @param value The ID of the instance or a fully qualified identifier for the instance.
* - - -
*/
@JvmName("rxthbvpiqpgcjkkj")
public suspend fun name(`value`: Output) {
this.name = value
}
/**
* @param value Looker Instance OAuth login settings.
* Structure is documented below.
*/
@JvmName("tiouilapdljkuwbq")
public suspend fun oauthConfig(`value`: Output) {
this.oauthConfig = value
}
/**
* @param value Platform editions for a Looker instance. Each edition maps to a set of instance features, like its size. Must be one of these values:
* - LOOKER_CORE_TRIAL: trial instance (Currently Unavailable)
* - LOOKER_CORE_STANDARD: pay as you go standard instance (Currently Unavailable)
* - LOOKER_CORE_STANDARD_ANNUAL: subscription standard instance
* - LOOKER_CORE_ENTERPRISE_ANNUAL: subscription enterprise instance
* - LOOKER_CORE_EMBED_ANNUAL: subscription embed instance
* Default value is `LOOKER_CORE_TRIAL`.
* Possible values are: `LOOKER_CORE_TRIAL`, `LOOKER_CORE_STANDARD`, `LOOKER_CORE_STANDARD_ANNUAL`, `LOOKER_CORE_ENTERPRISE_ANNUAL`, `LOOKER_CORE_EMBED_ANNUAL`.
*/
@JvmName("qjacyvkcmooxmupq")
public suspend fun platformEdition(`value`: Output) {
this.platformEdition = value
}
/**
* @param value Whether private IP is enabled on the Looker instance.
*/
@JvmName("nuabteqtjjtlihav")
public suspend fun privateIpEnabled(`value`: Output) {
this.privateIpEnabled = value
}
/**
* @param value The ID of the project in which the resource belongs.
* If it is not provided, the provider project is used.
*/
@JvmName("jnkrithovvucmugh")
public suspend fun project(`value`: Output) {
this.project = value
}
/**
* @param value Whether public IP is enabled on the Looker instance.
*/
@JvmName("wlcekjxqycldjmyx")
public suspend fun publicIpEnabled(`value`: Output) {
this.publicIpEnabled = value
}
/**
* @param value The name of the Looker region of the instance.
*/
@JvmName("vmcpnvhecryoiuio")
public suspend fun region(`value`: Output) {
this.region = value
}
/**
* @param value Name of a reserved IP address range within the consumer network, to be used for
* private service access connection. User may or may not specify this in a request.
*/
@JvmName("pbwohuxxchxhgkwa")
public suspend fun reservedRange(`value`: Output) {
this.reservedRange = value
}
/**
* @param value Metadata about users for a Looker instance.
* These settings are only available when platform edition LOOKER_CORE_STANDARD is set.
* There are ten Standard and two Developer users included in the cost of the product.
* You can allocate additional Standard, Viewer, and Developer users for this instance.
* It is an optional step and can be modified later.
* With the Standard edition of Looker (Google Cloud core), you can provision up to 50
* total users, distributed across Viewer, Standard, and Developer.
* Structure is documented below.
*/
@JvmName("vaihvndvfqohmfmn")
public suspend fun userMetadata(`value`: Output) {
this.userMetadata = value
}
/**
* @param value Looker instance Admin settings.
* Structure is documented below.
*/
@JvmName("dcttjmrkkjvnsjrw")
public suspend fun adminSettings(`value`: InstanceAdminSettingsArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.adminSettings = mapped
}
/**
* @param argument Looker instance Admin settings.
* Structure is documented below.
*/
@JvmName("kglnjyjtudjcseef")
public suspend fun adminSettings(argument: suspend InstanceAdminSettingsArgsBuilder.() -> Unit) {
val toBeMapped = InstanceAdminSettingsArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.adminSettings = mapped
}
/**
* @param value Network name in the consumer project in the format of: projects/{project}/global/networks/{network}
* Note that the consumer network may be in a different GCP project than the consumer
* project that is hosting the Looker Instance.
*/
@JvmName("dxypbfajcsdfkfwt")
public suspend fun consumerNetwork(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.consumerNetwork = mapped
}
/**
* @param value Custom domain settings for a Looker instance.
* Structure is documented below.
*/
@JvmName("cdlarrcotnnajttr")
public suspend fun customDomain(`value`: InstanceCustomDomainArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.customDomain = mapped
}
/**
* @param argument Custom domain settings for a Looker instance.
* Structure is documented below.
*/
@JvmName("qvutuvfsxefthhrs")
public suspend fun customDomain(argument: suspend InstanceCustomDomainArgsBuilder.() -> Unit) {
val toBeMapped = InstanceCustomDomainArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.customDomain = mapped
}
/**
* @param value Maintenance denial period for this instance.
* You must allow at least 14 days of maintenance availability
* between any two deny maintenance periods.
* Structure is documented below.
*/
@JvmName("gcegutchwqdlllbw")
public suspend fun denyMaintenancePeriod(`value`: InstanceDenyMaintenancePeriodArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.denyMaintenancePeriod = mapped
}
/**
* @param argument Maintenance denial period for this instance.
* You must allow at least 14 days of maintenance availability
* between any two deny maintenance periods.
* Structure is documented below.
*/
@JvmName("smdcmmbvbmvgdsbf")
public suspend fun denyMaintenancePeriod(argument: suspend InstanceDenyMaintenancePeriodArgsBuilder.() -> Unit) {
val toBeMapped = InstanceDenyMaintenancePeriodArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.denyMaintenancePeriod = mapped
}
/**
* @param value Looker instance encryption settings.
* Structure is documented below.
*/
@JvmName("rpcfdaxnjkqprmpn")
public suspend fun encryptionConfig(`value`: InstanceEncryptionConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.encryptionConfig = mapped
}
/**
* @param argument Looker instance encryption settings.
* Structure is documented below.
*/
@JvmName("jwsdywxxurlntbof")
public suspend fun encryptionConfig(argument: suspend InstanceEncryptionConfigArgsBuilder.() -> Unit) {
val toBeMapped = InstanceEncryptionConfigArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.encryptionConfig = mapped
}
/**
* @param value Maintenance window for an instance.
* Maintenance of your instance takes place once a month, and will require
* your instance to be restarted during updates, which will temporarily
* disrupt service.
* Structure is documented below.
*/
@JvmName("tjkehvglipbjeyqp")
public suspend fun maintenanceWindow(`value`: InstanceMaintenanceWindowArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.maintenanceWindow = mapped
}
/**
* @param argument Maintenance window for an instance.
* Maintenance of your instance takes place once a month, and will require
* your instance to be restarted during updates, which will temporarily
* disrupt service.
* Structure is documented below.
*/
@JvmName("kjqpsemtfrpwxpnf")
public suspend fun maintenanceWindow(argument: suspend InstanceMaintenanceWindowArgsBuilder.() -> Unit) {
val toBeMapped = InstanceMaintenanceWindowArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.maintenanceWindow = mapped
}
/**
* @param value The ID of the instance or a fully qualified identifier for the instance.
* - - -
*/
@JvmName("yjofcvqviduednlr")
public suspend fun name(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.name = mapped
}
/**
* @param value Looker Instance OAuth login settings.
* Structure is documented below.
*/
@JvmName("ypyuvryucehbmfwf")
public suspend fun oauthConfig(`value`: InstanceOauthConfigArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.oauthConfig = mapped
}
/**
* @param argument Looker Instance OAuth login settings.
* Structure is documented below.
*/
@JvmName("gtygnhlvhcbxohtn")
public suspend fun oauthConfig(argument: suspend InstanceOauthConfigArgsBuilder.() -> Unit) {
val toBeMapped = InstanceOauthConfigArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.oauthConfig = mapped
}
/**
* @param value Platform editions for a Looker instance. Each edition maps to a set of instance features, like its size. Must be one of these values:
* - LOOKER_CORE_TRIAL: trial instance (Currently Unavailable)
* - LOOKER_CORE_STANDARD: pay as you go standard instance (Currently Unavailable)
* - LOOKER_CORE_STANDARD_ANNUAL: subscription standard instance
* - LOOKER_CORE_ENTERPRISE_ANNUAL: subscription enterprise instance
* - LOOKER_CORE_EMBED_ANNUAL: subscription embed instance
* Default value is `LOOKER_CORE_TRIAL`.
* Possible values are: `LOOKER_CORE_TRIAL`, `LOOKER_CORE_STANDARD`, `LOOKER_CORE_STANDARD_ANNUAL`, `LOOKER_CORE_ENTERPRISE_ANNUAL`, `LOOKER_CORE_EMBED_ANNUAL`.
*/
@JvmName("vyqprhpnqshixhgt")
public suspend fun platformEdition(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.platformEdition = mapped
}
/**
* @param value Whether private IP is enabled on the Looker instance.
*/
@JvmName("pykndybdwyanblyo")
public suspend fun privateIpEnabled(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.privateIpEnabled = mapped
}
/**
* @param value The ID of the project in which the resource belongs.
* If it is not provided, the provider project is used.
*/
@JvmName("jpuaxgnluoltrkbp")
public suspend fun project(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.project = mapped
}
/**
* @param value Whether public IP is enabled on the Looker instance.
*/
@JvmName("vygefwoilkxpkyoi")
public suspend fun publicIpEnabled(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.publicIpEnabled = mapped
}
/**
* @param value The name of the Looker region of the instance.
*/
@JvmName("grtldtrgxqgyptto")
public suspend fun region(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.region = mapped
}
/**
* @param value Name of a reserved IP address range within the consumer network, to be used for
* private service access connection. User may or may not specify this in a request.
*/
@JvmName("kpglwhpijcmcvaiu")
public suspend fun reservedRange(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.reservedRange = mapped
}
/**
* @param value Metadata about users for a Looker instance.
* These settings are only available when platform edition LOOKER_CORE_STANDARD is set.
* There are ten Standard and two Developer users included in the cost of the product.
* You can allocate additional Standard, Viewer, and Developer users for this instance.
* It is an optional step and can be modified later.
* With the Standard edition of Looker (Google Cloud core), you can provision up to 50
* total users, distributed across Viewer, Standard, and Developer.
* Structure is documented below.
*/
@JvmName("jeklvoebdawopqag")
public suspend fun userMetadata(`value`: InstanceUserMetadataArgs?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.userMetadata = mapped
}
/**
* @param argument Metadata about users for a Looker instance.
* These settings are only available when platform edition LOOKER_CORE_STANDARD is set.
* There are ten Standard and two Developer users included in the cost of the product.
* You can allocate additional Standard, Viewer, and Developer users for this instance.
* It is an optional step and can be modified later.
* With the Standard edition of Looker (Google Cloud core), you can provision up to 50
* total users, distributed across Viewer, Standard, and Developer.
* Structure is documented below.
*/
@JvmName("chwhpoflgedfcjqe")
public suspend fun userMetadata(argument: suspend InstanceUserMetadataArgsBuilder.() -> Unit) {
val toBeMapped = InstanceUserMetadataArgsBuilder().applySuspend { argument() }.build()
val mapped = of(toBeMapped)
this.userMetadata = mapped
}
internal fun build(): InstanceArgs = InstanceArgs(
adminSettings = adminSettings,
consumerNetwork = consumerNetwork,
customDomain = customDomain,
denyMaintenancePeriod = denyMaintenancePeriod,
encryptionConfig = encryptionConfig,
maintenanceWindow = maintenanceWindow,
name = name,
oauthConfig = oauthConfig,
platformEdition = platformEdition,
privateIpEnabled = privateIpEnabled,
project = project,
publicIpEnabled = publicIpEnabled,
region = region,
reservedRange = reservedRange,
userMetadata = userMetadata,
)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy