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

com.pulumi.gcp.dataproc.kotlin.MetastoreService.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 8.12.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.dataproc.kotlin

import com.pulumi.core.Output
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceEncryptionConfig
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceHiveMetastoreConfig
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceMaintenanceWindow
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceMetadataIntegration
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceNetworkConfig
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceScalingConfig
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceScheduledBackup
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceTelemetryConfig
import com.pulumi.kotlin.KotlinCustomResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.CustomResourceOptions
import com.pulumi.kotlin.options.CustomResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Boolean
import kotlin.Int
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.Map
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceEncryptionConfig.Companion.toKotlin as metastoreServiceEncryptionConfigToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceHiveMetastoreConfig.Companion.toKotlin as metastoreServiceHiveMetastoreConfigToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceMaintenanceWindow.Companion.toKotlin as metastoreServiceMaintenanceWindowToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceMetadataIntegration.Companion.toKotlin as metastoreServiceMetadataIntegrationToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceNetworkConfig.Companion.toKotlin as metastoreServiceNetworkConfigToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceScalingConfig.Companion.toKotlin as metastoreServiceScalingConfigToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceScheduledBackup.Companion.toKotlin as metastoreServiceScheduledBackupToKotlin
import com.pulumi.gcp.dataproc.kotlin.outputs.MetastoreServiceTelemetryConfig.Companion.toKotlin as metastoreServiceTelemetryConfigToKotlin

/**
 * Builder for [MetastoreService].
 */
@PulumiTagMarker
public class MetastoreServiceResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: MetastoreServiceArgs = MetastoreServiceArgs()

    public var opts: CustomResourceOptions = CustomResourceOptions()

    /**
     * @param name The _unique_ name of the resulting resource.
     */
    public fun name(`value`: String) {
        this.name = value
    }

    /**
     * @param block The arguments to use to populate this resource's properties.
     */
    public suspend fun args(block: suspend MetastoreServiceArgsBuilder.() -> Unit) {
        val builder = MetastoreServiceArgsBuilder()
        block(builder)
        this.args = builder.build()
    }

    /**
     * @param block A bag of options that control this resource's behavior.
     */
    public suspend fun opts(block: suspend CustomResourceOptionsBuilder.() -> Unit) {
        this.opts = com.pulumi.kotlin.options.CustomResourceOptions.opts(block)
    }

    internal fun build(): MetastoreService {
        val builtJavaResource = com.pulumi.gcp.dataproc.MetastoreService(
            this.name,
            this.args.toJava(),
            this.opts.toJava(),
        )
        return MetastoreService(builtJavaResource)
    }
}

/**
 * A managed metastore service that serves metadata queries.
 * To get more information about Service, see:
 * * [API documentation](https://cloud.google.com/dataproc-metastore/docs/reference/rest/v1/projects.locations.services)
 * * How-to Guides
 *     * [Official Documentation](https://cloud.google.com/dataproc-metastore/docs/overview)
 * ## Example Usage
 * ### Dataproc Metastore Service Basic
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const _default = new gcp.dataproc.MetastoreService("default", {
 *     serviceId: "metastore-srv",
 *     location: "us-central1",
 *     port: 9080,
 *     tier: "DEVELOPER",
 *     maintenanceWindow: {
 *         hourOfDay: 2,
 *         dayOfWeek: "SUNDAY",
 *     },
 *     hiveMetastoreConfig: {
 *         version: "2.3.6",
 *     },
 *     labels: {
 *         env: "test",
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * default = gcp.dataproc.MetastoreService("default",
 *     service_id="metastore-srv",
 *     location="us-central1",
 *     port=9080,
 *     tier="DEVELOPER",
 *     maintenance_window=gcp.dataproc.MetastoreServiceMaintenanceWindowArgs(
 *         hour_of_day=2,
 *         day_of_week="SUNDAY",
 *     ),
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="2.3.6",
 *     ),
 *     labels={
 *         "env": "test",
 *     })
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var @default = new Gcp.Dataproc.MetastoreService("default", new()
 *     {
 *         ServiceId = "metastore-srv",
 *         Location = "us-central1",
 *         Port = 9080,
 *         Tier = "DEVELOPER",
 *         MaintenanceWindow = new Gcp.Dataproc.Inputs.MetastoreServiceMaintenanceWindowArgs
 *         {
 *             HourOfDay = 2,
 *             DayOfWeek = "SUNDAY",
 *         },
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "2.3.6",
 *         },
 *         Labels =
 *         {
 *             { "env", "test" },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := dataproc.NewMetastoreService(ctx, "default", &dataproc.MetastoreServiceArgs{
 * 			ServiceId: pulumi.String("metastore-srv"),
 * 			Location:  pulumi.String("us-central1"),
 * 			Port:      pulumi.Int(9080),
 * 			Tier:      pulumi.String("DEVELOPER"),
 * 			MaintenanceWindow: &dataproc.MetastoreServiceMaintenanceWindowArgs{
 * 				HourOfDay: pulumi.Int(2),
 * 				DayOfWeek: pulumi.String("SUNDAY"),
 * 			},
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("2.3.6"),
 * 			},
 * 			Labels: pulumi.StringMap{
 * 				"env": pulumi.String("test"),
 * 			},
 * 		})
 * 		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.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceMaintenanceWindowArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * 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 default_ = new MetastoreService("default", MetastoreServiceArgs.builder()
 *             .serviceId("metastore-srv")
 *             .location("us-central1")
 *             .port(9080)
 *             .tier("DEVELOPER")
 *             .maintenanceWindow(MetastoreServiceMaintenanceWindowArgs.builder()
 *                 .hourOfDay(2)
 *                 .dayOfWeek("SUNDAY")
 *                 .build())
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("2.3.6")
 *                 .build())
 *             .labels(Map.of("env", "test"))
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   default:
 *     type: gcp:dataproc:MetastoreService
 *     properties:
 *       serviceId: metastore-srv
 *       location: us-central1
 *       port: 9080
 *       tier: DEVELOPER
 *       maintenanceWindow:
 *         hourOfDay: 2
 *         dayOfWeek: SUNDAY
 *       hiveMetastoreConfig:
 *         version: 2.3.6
 *       labels:
 *         env: test
 * ```
 * 
 * ### Dataproc Metastore Service Cmek Example
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const keyRing = new gcp.kms.KeyRing("key_ring", {
 *     name: "example-keyring",
 *     location: "us-central1",
 * });
 * const cryptoKey = new gcp.kms.CryptoKey("crypto_key", {
 *     name: "example-key",
 *     keyRing: keyRing.id,
 *     purpose: "ENCRYPT_DECRYPT",
 * });
 * const _default = new gcp.dataproc.MetastoreService("default", {
 *     serviceId: "example-service",
 *     location: "us-central1",
 *     encryptionConfig: {
 *         kmsKey: cryptoKey.id,
 *     },
 *     hiveMetastoreConfig: {
 *         version: "3.1.2",
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * key_ring = gcp.kms.KeyRing("key_ring",
 *     name="example-keyring",
 *     location="us-central1")
 * crypto_key = gcp.kms.CryptoKey("crypto_key",
 *     name="example-key",
 *     key_ring=key_ring.id,
 *     purpose="ENCRYPT_DECRYPT")
 * default = gcp.dataproc.MetastoreService("default",
 *     service_id="example-service",
 *     location="us-central1",
 *     encryption_config=gcp.dataproc.MetastoreServiceEncryptionConfigArgs(
 *         kms_key=crypto_key.id,
 *     ),
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="3.1.2",
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var keyRing = new Gcp.Kms.KeyRing("key_ring", new()
 *     {
 *         Name = "example-keyring",
 *         Location = "us-central1",
 *     });
 *     var cryptoKey = new Gcp.Kms.CryptoKey("crypto_key", new()
 *     {
 *         Name = "example-key",
 *         KeyRing = keyRing.Id,
 *         Purpose = "ENCRYPT_DECRYPT",
 *     });
 *     var @default = new Gcp.Dataproc.MetastoreService("default", new()
 *     {
 *         ServiceId = "example-service",
 *         Location = "us-central1",
 *         EncryptionConfig = new Gcp.Dataproc.Inputs.MetastoreServiceEncryptionConfigArgs
 *         {
 *             KmsKey = cryptoKey.Id,
 *         },
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "3.1.2",
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/kms"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		keyRing, err := kms.NewKeyRing(ctx, "key_ring", &kms.KeyRingArgs{
 * 			Name:     pulumi.String("example-keyring"),
 * 			Location: pulumi.String("us-central1"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		cryptoKey, err := kms.NewCryptoKey(ctx, "crypto_key", &kms.CryptoKeyArgs{
 * 			Name:    pulumi.String("example-key"),
 * 			KeyRing: keyRing.ID(),
 * 			Purpose: pulumi.String("ENCRYPT_DECRYPT"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = dataproc.NewMetastoreService(ctx, "default", &dataproc.MetastoreServiceArgs{
 * 			ServiceId: pulumi.String("example-service"),
 * 			Location:  pulumi.String("us-central1"),
 * 			EncryptionConfig: &dataproc.MetastoreServiceEncryptionConfigArgs{
 * 				KmsKey: cryptoKey.ID(),
 * 			},
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("3.1.2"),
 * 			},
 * 		})
 * 		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.kms.KeyRing;
 * import com.pulumi.gcp.kms.KeyRingArgs;
 * import com.pulumi.gcp.kms.CryptoKey;
 * import com.pulumi.gcp.kms.CryptoKeyArgs;
 * import com.pulumi.gcp.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceEncryptionConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * 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 keyRing = new KeyRing("keyRing", KeyRingArgs.builder()
 *             .name("example-keyring")
 *             .location("us-central1")
 *             .build());
 *         var cryptoKey = new CryptoKey("cryptoKey", CryptoKeyArgs.builder()
 *             .name("example-key")
 *             .keyRing(keyRing.id())
 *             .purpose("ENCRYPT_DECRYPT")
 *             .build());
 *         var default_ = new MetastoreService("default", MetastoreServiceArgs.builder()
 *             .serviceId("example-service")
 *             .location("us-central1")
 *             .encryptionConfig(MetastoreServiceEncryptionConfigArgs.builder()
 *                 .kmsKey(cryptoKey.id())
 *                 .build())
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("3.1.2")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   default:
 *     type: gcp:dataproc:MetastoreService
 *     properties:
 *       serviceId: example-service
 *       location: us-central1
 *       encryptionConfig:
 *         kmsKey: ${cryptoKey.id}
 *       hiveMetastoreConfig:
 *         version: 3.1.2
 *   cryptoKey:
 *     type: gcp:kms:CryptoKey
 *     name: crypto_key
 *     properties:
 *       name: example-key
 *       keyRing: ${keyRing.id}
 *       purpose: ENCRYPT_DECRYPT
 *   keyRing:
 *     type: gcp:kms:KeyRing
 *     name: key_ring
 *     properties:
 *       name: example-keyring
 *       location: us-central1
 * ```
 * 
 * ### Dataproc Metastore Service Private Service Connect
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const net = new gcp.compute.Network("net", {
 *     name: "my-network",
 *     autoCreateSubnetworks: false,
 * });
 * const subnet = new gcp.compute.Subnetwork("subnet", {
 *     name: "my-subnetwork",
 *     region: "us-central1",
 *     network: net.id,
 *     ipCidrRange: "10.0.0.0/22",
 *     privateIpGoogleAccess: true,
 * });
 * const _default = new gcp.dataproc.MetastoreService("default", {
 *     serviceId: "metastore-srv",
 *     location: "us-central1",
 *     hiveMetastoreConfig: {
 *         version: "3.1.2",
 *     },
 *     networkConfig: {
 *         consumers: [{
 *             subnetwork: subnet.id,
 *         }],
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * net = gcp.compute.Network("net",
 *     name="my-network",
 *     auto_create_subnetworks=False)
 * subnet = gcp.compute.Subnetwork("subnet",
 *     name="my-subnetwork",
 *     region="us-central1",
 *     network=net.id,
 *     ip_cidr_range="10.0.0.0/22",
 *     private_ip_google_access=True)
 * default = gcp.dataproc.MetastoreService("default",
 *     service_id="metastore-srv",
 *     location="us-central1",
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="3.1.2",
 *     ),
 *     network_config=gcp.dataproc.MetastoreServiceNetworkConfigArgs(
 *         consumers=[gcp.dataproc.MetastoreServiceNetworkConfigConsumerArgs(
 *             subnetwork=subnet.id,
 *         )],
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var net = new Gcp.Compute.Network("net", new()
 *     {
 *         Name = "my-network",
 *         AutoCreateSubnetworks = false,
 *     });
 *     var subnet = new Gcp.Compute.Subnetwork("subnet", new()
 *     {
 *         Name = "my-subnetwork",
 *         Region = "us-central1",
 *         Network = net.Id,
 *         IpCidrRange = "10.0.0.0/22",
 *         PrivateIpGoogleAccess = true,
 *     });
 *     var @default = new Gcp.Dataproc.MetastoreService("default", new()
 *     {
 *         ServiceId = "metastore-srv",
 *         Location = "us-central1",
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "3.1.2",
 *         },
 *         NetworkConfig = new Gcp.Dataproc.Inputs.MetastoreServiceNetworkConfigArgs
 *         {
 *             Consumers = new[]
 *             {
 *                 new Gcp.Dataproc.Inputs.MetastoreServiceNetworkConfigConsumerArgs
 *                 {
 *                     Subnetwork = subnet.Id,
 *                 },
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		net, err := compute.NewNetwork(ctx, "net", &compute.NetworkArgs{
 * 			Name:                  pulumi.String("my-network"),
 * 			AutoCreateSubnetworks: pulumi.Bool(false),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		subnet, err := compute.NewSubnetwork(ctx, "subnet", &compute.SubnetworkArgs{
 * 			Name:                  pulumi.String("my-subnetwork"),
 * 			Region:                pulumi.String("us-central1"),
 * 			Network:               net.ID(),
 * 			IpCidrRange:           pulumi.String("10.0.0.0/22"),
 * 			PrivateIpGoogleAccess: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = dataproc.NewMetastoreService(ctx, "default", &dataproc.MetastoreServiceArgs{
 * 			ServiceId: pulumi.String("metastore-srv"),
 * 			Location:  pulumi.String("us-central1"),
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("3.1.2"),
 * 			},
 * 			NetworkConfig: &dataproc.MetastoreServiceNetworkConfigArgs{
 * 				Consumers: dataproc.MetastoreServiceNetworkConfigConsumerArray{
 * 					&dataproc.MetastoreServiceNetworkConfigConsumerArgs{
 * 						Subnetwork: subnet.ID(),
 * 					},
 * 				},
 * 			},
 * 		})
 * 		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.Subnetwork;
 * import com.pulumi.gcp.compute.SubnetworkArgs;
 * import com.pulumi.gcp.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceNetworkConfigArgs;
 * 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 net = new Network("net", NetworkArgs.builder()
 *             .name("my-network")
 *             .autoCreateSubnetworks(false)
 *             .build());
 *         var subnet = new Subnetwork("subnet", SubnetworkArgs.builder()
 *             .name("my-subnetwork")
 *             .region("us-central1")
 *             .network(net.id())
 *             .ipCidrRange("10.0.0.0/22")
 *             .privateIpGoogleAccess(true)
 *             .build());
 *         var default_ = new MetastoreService("default", MetastoreServiceArgs.builder()
 *             .serviceId("metastore-srv")
 *             .location("us-central1")
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("3.1.2")
 *                 .build())
 *             .networkConfig(MetastoreServiceNetworkConfigArgs.builder()
 *                 .consumers(MetastoreServiceNetworkConfigConsumerArgs.builder()
 *                     .subnetwork(subnet.id())
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   net:
 *     type: gcp:compute:Network
 *     properties:
 *       name: my-network
 *       autoCreateSubnetworks: false
 *   subnet:
 *     type: gcp:compute:Subnetwork
 *     properties:
 *       name: my-subnetwork
 *       region: us-central1
 *       network: ${net.id}
 *       ipCidrRange: 10.0.0.0/22
 *       privateIpGoogleAccess: true
 *   default:
 *     type: gcp:dataproc:MetastoreService
 *     properties:
 *       serviceId: metastore-srv
 *       location: us-central1
 *       hiveMetastoreConfig:
 *         version: 3.1.2
 *       networkConfig:
 *         consumers:
 *           - subnetwork: ${subnet.id}
 * ```
 * 
 * ### Dataproc Metastore Service Private Service Connect Custom Routes
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const net = new gcp.compute.Network("net", {
 *     name: "my-network",
 *     autoCreateSubnetworks: false,
 * });
 * const subnet = new gcp.compute.Subnetwork("subnet", {
 *     name: "my-subnetwork",
 *     region: "us-central1",
 *     network: net.id,
 *     ipCidrRange: "10.0.0.0/22",
 *     privateIpGoogleAccess: true,
 * });
 * const _default = new gcp.dataproc.MetastoreService("default", {
 *     serviceId: "metastore-srv",
 *     location: "us-central1",
 *     hiveMetastoreConfig: {
 *         version: "3.1.2",
 *     },
 *     networkConfig: {
 *         consumers: [{
 *             subnetwork: subnet.id,
 *         }],
 *         customRoutesEnabled: true,
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * net = gcp.compute.Network("net",
 *     name="my-network",
 *     auto_create_subnetworks=False)
 * subnet = gcp.compute.Subnetwork("subnet",
 *     name="my-subnetwork",
 *     region="us-central1",
 *     network=net.id,
 *     ip_cidr_range="10.0.0.0/22",
 *     private_ip_google_access=True)
 * default = gcp.dataproc.MetastoreService("default",
 *     service_id="metastore-srv",
 *     location="us-central1",
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="3.1.2",
 *     ),
 *     network_config=gcp.dataproc.MetastoreServiceNetworkConfigArgs(
 *         consumers=[gcp.dataproc.MetastoreServiceNetworkConfigConsumerArgs(
 *             subnetwork=subnet.id,
 *         )],
 *         custom_routes_enabled=True,
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var net = new Gcp.Compute.Network("net", new()
 *     {
 *         Name = "my-network",
 *         AutoCreateSubnetworks = false,
 *     });
 *     var subnet = new Gcp.Compute.Subnetwork("subnet", new()
 *     {
 *         Name = "my-subnetwork",
 *         Region = "us-central1",
 *         Network = net.Id,
 *         IpCidrRange = "10.0.0.0/22",
 *         PrivateIpGoogleAccess = true,
 *     });
 *     var @default = new Gcp.Dataproc.MetastoreService("default", new()
 *     {
 *         ServiceId = "metastore-srv",
 *         Location = "us-central1",
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "3.1.2",
 *         },
 *         NetworkConfig = new Gcp.Dataproc.Inputs.MetastoreServiceNetworkConfigArgs
 *         {
 *             Consumers = new[]
 *             {
 *                 new Gcp.Dataproc.Inputs.MetastoreServiceNetworkConfigConsumerArgs
 *                 {
 *                     Subnetwork = subnet.Id,
 *                 },
 *             },
 *             CustomRoutesEnabled = true,
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/compute"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		net, err := compute.NewNetwork(ctx, "net", &compute.NetworkArgs{
 * 			Name:                  pulumi.String("my-network"),
 * 			AutoCreateSubnetworks: pulumi.Bool(false),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		subnet, err := compute.NewSubnetwork(ctx, "subnet", &compute.SubnetworkArgs{
 * 			Name:                  pulumi.String("my-subnetwork"),
 * 			Region:                pulumi.String("us-central1"),
 * 			Network:               net.ID(),
 * 			IpCidrRange:           pulumi.String("10.0.0.0/22"),
 * 			PrivateIpGoogleAccess: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = dataproc.NewMetastoreService(ctx, "default", &dataproc.MetastoreServiceArgs{
 * 			ServiceId: pulumi.String("metastore-srv"),
 * 			Location:  pulumi.String("us-central1"),
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("3.1.2"),
 * 			},
 * 			NetworkConfig: &dataproc.MetastoreServiceNetworkConfigArgs{
 * 				Consumers: dataproc.MetastoreServiceNetworkConfigConsumerArray{
 * 					&dataproc.MetastoreServiceNetworkConfigConsumerArgs{
 * 						Subnetwork: subnet.ID(),
 * 					},
 * 				},
 * 				CustomRoutesEnabled: pulumi.Bool(true),
 * 			},
 * 		})
 * 		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.Subnetwork;
 * import com.pulumi.gcp.compute.SubnetworkArgs;
 * import com.pulumi.gcp.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceNetworkConfigArgs;
 * 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 net = new Network("net", NetworkArgs.builder()
 *             .name("my-network")
 *             .autoCreateSubnetworks(false)
 *             .build());
 *         var subnet = new Subnetwork("subnet", SubnetworkArgs.builder()
 *             .name("my-subnetwork")
 *             .region("us-central1")
 *             .network(net.id())
 *             .ipCidrRange("10.0.0.0/22")
 *             .privateIpGoogleAccess(true)
 *             .build());
 *         var default_ = new MetastoreService("default", MetastoreServiceArgs.builder()
 *             .serviceId("metastore-srv")
 *             .location("us-central1")
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("3.1.2")
 *                 .build())
 *             .networkConfig(MetastoreServiceNetworkConfigArgs.builder()
 *                 .consumers(MetastoreServiceNetworkConfigConsumerArgs.builder()
 *                     .subnetwork(subnet.id())
 *                     .build())
 *                 .customRoutesEnabled(true)
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   net:
 *     type: gcp:compute:Network
 *     properties:
 *       name: my-network
 *       autoCreateSubnetworks: false
 *   subnet:
 *     type: gcp:compute:Subnetwork
 *     properties:
 *       name: my-subnetwork
 *       region: us-central1
 *       network: ${net.id}
 *       ipCidrRange: 10.0.0.0/22
 *       privateIpGoogleAccess: true
 *   default:
 *     type: gcp:dataproc:MetastoreService
 *     properties:
 *       serviceId: metastore-srv
 *       location: us-central1
 *       hiveMetastoreConfig:
 *         version: 3.1.2
 *       networkConfig:
 *         consumers:
 *           - subnetwork: ${subnet.id}
 *         customRoutesEnabled: true
 * ```
 * 
 * ### Dataproc Metastore Service Dpms2
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const dpms2 = new gcp.dataproc.MetastoreService("dpms2", {
 *     serviceId: "ms-dpms2",
 *     location: "us-central1",
 *     databaseType: "SPANNER",
 *     hiveMetastoreConfig: {
 *         version: "3.1.2",
 *     },
 *     scalingConfig: {
 *         instanceSize: "EXTRA_SMALL",
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * dpms2 = gcp.dataproc.MetastoreService("dpms2",
 *     service_id="ms-dpms2",
 *     location="us-central1",
 *     database_type="SPANNER",
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="3.1.2",
 *     ),
 *     scaling_config=gcp.dataproc.MetastoreServiceScalingConfigArgs(
 *         instance_size="EXTRA_SMALL",
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var dpms2 = new Gcp.Dataproc.MetastoreService("dpms2", new()
 *     {
 *         ServiceId = "ms-dpms2",
 *         Location = "us-central1",
 *         DatabaseType = "SPANNER",
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "3.1.2",
 *         },
 *         ScalingConfig = new Gcp.Dataproc.Inputs.MetastoreServiceScalingConfigArgs
 *         {
 *             InstanceSize = "EXTRA_SMALL",
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := dataproc.NewMetastoreService(ctx, "dpms2", &dataproc.MetastoreServiceArgs{
 * 			ServiceId:    pulumi.String("ms-dpms2"),
 * 			Location:     pulumi.String("us-central1"),
 * 			DatabaseType: pulumi.String("SPANNER"),
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("3.1.2"),
 * 			},
 * 			ScalingConfig: &dataproc.MetastoreServiceScalingConfigArgs{
 * 				InstanceSize: pulumi.String("EXTRA_SMALL"),
 * 			},
 * 		})
 * 		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.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceScalingConfigArgs;
 * 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 dpms2 = new MetastoreService("dpms2", MetastoreServiceArgs.builder()
 *             .serviceId("ms-dpms2")
 *             .location("us-central1")
 *             .databaseType("SPANNER")
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("3.1.2")
 *                 .build())
 *             .scalingConfig(MetastoreServiceScalingConfigArgs.builder()
 *                 .instanceSize("EXTRA_SMALL")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   dpms2:
 *     type: gcp:dataproc:MetastoreService
 *     properties:
 *       serviceId: ms-dpms2
 *       location: us-central1
 *       databaseType: SPANNER
 *       hiveMetastoreConfig:
 *         version: 3.1.2
 *       scalingConfig:
 *         instanceSize: EXTRA_SMALL
 * ```
 * 
 * ### Dataproc Metastore Service Dpms2 Scaling Factor
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const dpms2ScalingFactor = new gcp.dataproc.MetastoreService("dpms2_scaling_factor", {
 *     serviceId: "ms-dpms2sf",
 *     location: "us-central1",
 *     databaseType: "SPANNER",
 *     hiveMetastoreConfig: {
 *         version: "3.1.2",
 *     },
 *     scalingConfig: {
 *         scalingFactor: 2,
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * dpms2_scaling_factor = gcp.dataproc.MetastoreService("dpms2_scaling_factor",
 *     service_id="ms-dpms2sf",
 *     location="us-central1",
 *     database_type="SPANNER",
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="3.1.2",
 *     ),
 *     scaling_config=gcp.dataproc.MetastoreServiceScalingConfigArgs(
 *         scaling_factor=2,
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var dpms2ScalingFactor = new Gcp.Dataproc.MetastoreService("dpms2_scaling_factor", new()
 *     {
 *         ServiceId = "ms-dpms2sf",
 *         Location = "us-central1",
 *         DatabaseType = "SPANNER",
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "3.1.2",
 *         },
 *         ScalingConfig = new Gcp.Dataproc.Inputs.MetastoreServiceScalingConfigArgs
 *         {
 *             ScalingFactor = 2,
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := dataproc.NewMetastoreService(ctx, "dpms2_scaling_factor", &dataproc.MetastoreServiceArgs{
 * 			ServiceId:    pulumi.String("ms-dpms2sf"),
 * 			Location:     pulumi.String("us-central1"),
 * 			DatabaseType: pulumi.String("SPANNER"),
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("3.1.2"),
 * 			},
 * 			ScalingConfig: &dataproc.MetastoreServiceScalingConfigArgs{
 * 				ScalingFactor: pulumi.Float64(2),
 * 			},
 * 		})
 * 		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.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceScalingConfigArgs;
 * 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 dpms2ScalingFactor = new MetastoreService("dpms2ScalingFactor", MetastoreServiceArgs.builder()
 *             .serviceId("ms-dpms2sf")
 *             .location("us-central1")
 *             .databaseType("SPANNER")
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("3.1.2")
 *                 .build())
 *             .scalingConfig(MetastoreServiceScalingConfigArgs.builder()
 *                 .scalingFactor("2")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   dpms2ScalingFactor:
 *     type: gcp:dataproc:MetastoreService
 *     name: dpms2_scaling_factor
 *     properties:
 *       serviceId: ms-dpms2sf
 *       location: us-central1
 *       databaseType: SPANNER
 *       hiveMetastoreConfig:
 *         version: 3.1.2
 *       scalingConfig:
 *         scalingFactor: '2'
 * ```
 * 
 * ### Dataproc Metastore Service Scheduled Backup
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const bucket = new gcp.storage.Bucket("bucket", {
 *     name: "backup",
 *     location: "us-central1",
 * });
 * const backup = new gcp.dataproc.MetastoreService("backup", {
 *     serviceId: "backup",
 *     location: "us-central1",
 *     port: 9080,
 *     tier: "DEVELOPER",
 *     maintenanceWindow: {
 *         hourOfDay: 2,
 *         dayOfWeek: "SUNDAY",
 *     },
 *     hiveMetastoreConfig: {
 *         version: "2.3.6",
 *     },
 *     scheduledBackup: {
 *         enabled: true,
 *         cronSchedule: "0 0 * * *",
 *         timeZone: "UTC",
 *         backupLocation: pulumi.interpolate`gs://${bucket.name}`,
 *     },
 *     labels: {
 *         env: "test",
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * bucket = gcp.storage.Bucket("bucket",
 *     name="backup",
 *     location="us-central1")
 * backup = gcp.dataproc.MetastoreService("backup",
 *     service_id="backup",
 *     location="us-central1",
 *     port=9080,
 *     tier="DEVELOPER",
 *     maintenance_window=gcp.dataproc.MetastoreServiceMaintenanceWindowArgs(
 *         hour_of_day=2,
 *         day_of_week="SUNDAY",
 *     ),
 *     hive_metastore_config=gcp.dataproc.MetastoreServiceHiveMetastoreConfigArgs(
 *         version="2.3.6",
 *     ),
 *     scheduled_backup=gcp.dataproc.MetastoreServiceScheduledBackupArgs(
 *         enabled=True,
 *         cron_schedule="0 0 * * *",
 *         time_zone="UTC",
 *         backup_location=bucket.name.apply(lambda name: f"gs://{name}"),
 *     ),
 *     labels={
 *         "env": "test",
 *     })
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var bucket = new Gcp.Storage.Bucket("bucket", new()
 *     {
 *         Name = "backup",
 *         Location = "us-central1",
 *     });
 *     var backup = new Gcp.Dataproc.MetastoreService("backup", new()
 *     {
 *         ServiceId = "backup",
 *         Location = "us-central1",
 *         Port = 9080,
 *         Tier = "DEVELOPER",
 *         MaintenanceWindow = new Gcp.Dataproc.Inputs.MetastoreServiceMaintenanceWindowArgs
 *         {
 *             HourOfDay = 2,
 *             DayOfWeek = "SUNDAY",
 *         },
 *         HiveMetastoreConfig = new Gcp.Dataproc.Inputs.MetastoreServiceHiveMetastoreConfigArgs
 *         {
 *             Version = "2.3.6",
 *         },
 *         ScheduledBackup = new Gcp.Dataproc.Inputs.MetastoreServiceScheduledBackupArgs
 *         {
 *             Enabled = true,
 *             CronSchedule = "0 0 * * *",
 *             TimeZone = "UTC",
 *             BackupLocation = bucket.Name.Apply(name => $"gs://{name}"),
 *         },
 *         Labels =
 *         {
 *             { "env", "test" },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"fmt"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/dataproc"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		bucket, err := storage.NewBucket(ctx, "bucket", &storage.BucketArgs{
 * 			Name:     pulumi.String("backup"),
 * 			Location: pulumi.String("us-central1"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = dataproc.NewMetastoreService(ctx, "backup", &dataproc.MetastoreServiceArgs{
 * 			ServiceId: pulumi.String("backup"),
 * 			Location:  pulumi.String("us-central1"),
 * 			Port:      pulumi.Int(9080),
 * 			Tier:      pulumi.String("DEVELOPER"),
 * 			MaintenanceWindow: &dataproc.MetastoreServiceMaintenanceWindowArgs{
 * 				HourOfDay: pulumi.Int(2),
 * 				DayOfWeek: pulumi.String("SUNDAY"),
 * 			},
 * 			HiveMetastoreConfig: &dataproc.MetastoreServiceHiveMetastoreConfigArgs{
 * 				Version: pulumi.String("2.3.6"),
 * 			},
 * 			ScheduledBackup: &dataproc.MetastoreServiceScheduledBackupArgs{
 * 				Enabled:      pulumi.Bool(true),
 * 				CronSchedule: pulumi.String("0 0 * * *"),
 * 				TimeZone:     pulumi.String("UTC"),
 * 				BackupLocation: bucket.Name.ApplyT(func(name string) (string, error) {
 * 					return fmt.Sprintf("gs://%v", name), nil
 * 				}).(pulumi.StringOutput),
 * 			},
 * 			Labels: pulumi.StringMap{
 * 				"env": pulumi.String("test"),
 * 			},
 * 		})
 * 		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.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.dataproc.MetastoreService;
 * import com.pulumi.gcp.dataproc.MetastoreServiceArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceMaintenanceWindowArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceHiveMetastoreConfigArgs;
 * import com.pulumi.gcp.dataproc.inputs.MetastoreServiceScheduledBackupArgs;
 * 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 bucket = new Bucket("bucket", BucketArgs.builder()
 *             .name("backup")
 *             .location("us-central1")
 *             .build());
 *         var backup = new MetastoreService("backup", MetastoreServiceArgs.builder()
 *             .serviceId("backup")
 *             .location("us-central1")
 *             .port(9080)
 *             .tier("DEVELOPER")
 *             .maintenanceWindow(MetastoreServiceMaintenanceWindowArgs.builder()
 *                 .hourOfDay(2)
 *                 .dayOfWeek("SUNDAY")
 *                 .build())
 *             .hiveMetastoreConfig(MetastoreServiceHiveMetastoreConfigArgs.builder()
 *                 .version("2.3.6")
 *                 .build())
 *             .scheduledBackup(MetastoreServiceScheduledBackupArgs.builder()
 *                 .enabled(true)
 *                 .cronSchedule("0 0 * * *")
 *                 .timeZone("UTC")
 *                 .backupLocation(bucket.name().applyValue(name -> String.format("gs://%s", name)))
 *                 .build())
 *             .labels(Map.of("env", "test"))
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   backup:
 *     type: gcp:dataproc:MetastoreService
 *     properties:
 *       serviceId: backup
 *       location: us-central1
 *       port: 9080
 *       tier: DEVELOPER
 *       maintenanceWindow:
 *         hourOfDay: 2
 *         dayOfWeek: SUNDAY
 *       hiveMetastoreConfig:
 *         version: 2.3.6
 *       scheduledBackup:
 *         enabled: true
 *         cronSchedule: 0 0 * * *
 *         timeZone: UTC
 *         backupLocation: gs://${bucket.name}
 *       labels:
 *         env: test
 *   bucket:
 *     type: gcp:storage:Bucket
 *     properties:
 *       name: backup
 *       location: us-central1
 * ```
 * 
 * ## Import
 * Service can be imported using any of these accepted formats:
 * * `projects/{{project}}/locations/{{location}}/services/{{service_id}}`
 * * `{{project}}/{{location}}/{{service_id}}`
 * * `{{location}}/{{service_id}}`
 * When using the `pulumi import` command, Service can be imported using one of the formats above. For example:
 * ```sh
 * $ pulumi import gcp:dataproc/metastoreService:MetastoreService default projects/{{project}}/locations/{{location}}/services/{{service_id}}
 * ```
 * ```sh
 * $ pulumi import gcp:dataproc/metastoreService:MetastoreService default {{project}}/{{location}}/{{service_id}}
 * ```
 * ```sh
 * $ pulumi import gcp:dataproc/metastoreService:MetastoreService default {{location}}/{{service_id}}
 * ```
 */
public class MetastoreService internal constructor(
    override val javaResource: com.pulumi.gcp.dataproc.MetastoreService,
) : KotlinCustomResource(javaResource, MetastoreServiceMapper) {
    /**
     * A Cloud Storage URI (starting with gs://) that specifies where artifacts related to the metastore service are stored.
     */
    public val artifactGcsUri: Output
        get() = javaResource.artifactGcsUri().applyValue({ args0 -> args0 })

    /**
     * The database type that the Metastore service stores its data.
     * Default value is `MYSQL`.
     * Possible values are: `MYSQL`, `SPANNER`.
     */
    public val databaseType: Output?
        get() = javaResource.databaseType().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * All of labels (key/value pairs) present on the resource in GCP, including the labels configured through Pulumi, other clients and services.
     */
    public val effectiveLabels: Output>
        get() = javaResource.effectiveLabels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * Information used to configure the Dataproc Metastore service to encrypt
     * customer data at rest.
     * Structure is documented below.
     */
    public val encryptionConfig: Output?
        get() = javaResource.encryptionConfig().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceEncryptionConfigToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The URI of the endpoint used to access the metastore service.
     */
    public val endpointUri: Output
        get() = javaResource.endpointUri().applyValue({ args0 -> args0 })

    /**
     * Configuration information specific to running Hive metastore software as the metastore service.
     * Structure is documented below.
     */
    public val hiveMetastoreConfig: Output?
        get() = javaResource.hiveMetastoreConfig().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceHiveMetastoreConfigToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * User-defined labels for the metastore service.
     * **Note**: This field is non-authoritative, and will only manage the labels present in your configuration.
     * Please refer to the field `effective_labels` for all of the labels present on the resource.
     */
    public val labels: Output>?
        get() = javaResource.labels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.key.to(args0.value)
                }).toMap()
            }).orElse(null)
        })

    /**
     * The location where the metastore service should reside.
     * The default value is `global`.
     */
    public val location: Output?
        get() = javaResource.location().applyValue({ args0 -> args0.map({ args0 -> args0 }).orElse(null) })

    /**
     * The one hour maintenance window of the metastore service.
     * This specifies when the service can be restarted for maintenance purposes in UTC time.
     * Maintenance window is not needed for services with the `SPANNER` database type.
     * Structure is documented below.
     */
    public val maintenanceWindow: Output?
        get() = javaResource.maintenanceWindow().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceMaintenanceWindowToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The setting that defines how metastore metadata should be integrated with external services and systems.
     * Structure is documented below.
     */
    public val metadataIntegration: Output?
        get() = javaResource.metadataIntegration().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceMetadataIntegrationToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The relative resource name of the metastore service.
     */
    public val name: Output
        get() = javaResource.name().applyValue({ args0 -> args0 })

    /**
     * The relative resource name of the VPC network on which the instance can be accessed. It is specified in the following form:
     * "projects/{projectNumber}/global/networks/{network_id}".
     */
    public val network: Output
        get() = javaResource.network().applyValue({ args0 -> args0 })

    /**
     * The configuration specifying the network settings for the Dataproc Metastore service.
     * Structure is documented below.
     */
    public val networkConfig: Output?
        get() = javaResource.networkConfig().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceNetworkConfigToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The TCP port at which the metastore service is reached. Default: 9083.
     */
    public val port: Output
        get() = javaResource.port().applyValue({ args0 -> args0 })

    /**
     * The ID of the project in which the resource belongs.
     * If it is not provided, the provider project is used.
     */
    public val project: Output
        get() = javaResource.project().applyValue({ args0 -> args0 })

    /**
     * The combination of labels configured directly on the resource
     * and default labels configured on the provider.
     */
    public val pulumiLabels: Output>
        get() = javaResource.pulumiLabels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * The release channel of the service. If unspecified, defaults to `STABLE`.
     * Default value is `STABLE`.
     * Possible values are: `CANARY`, `STABLE`.
     */
    public val releaseChannel: Output?
        get() = javaResource.releaseChannel().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * Represents the scaling configuration of a metastore service.
     * Structure is documented below.
     */
    public val scalingConfig: Output?
        get() = javaResource.scalingConfig().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceScalingConfigToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The configuration of scheduled backup for the metastore service.
     * Structure is documented below.
     */
    public val scheduledBackup: Output?
        get() = javaResource.scheduledBackup().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> metastoreServiceScheduledBackupToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The ID of the metastore service. The id must contain only letters (a-z, A-Z), numbers (0-9), underscores (_),
     * and hyphens (-). Cannot begin or end with underscore or hyphen. Must consist of between
     * 3 and 63 characters.
     * - - -
     */
    public val serviceId: Output
        get() = javaResource.serviceId().applyValue({ args0 -> args0 })

    /**
     * The current state of the metastore service.
     */
    public val state: Output
        get() = javaResource.state().applyValue({ args0 -> args0 })

    /**
     * Additional information about the current state of the metastore service, if available.
     */
    public val stateMessage: Output
        get() = javaResource.stateMessage().applyValue({ args0 -> args0 })

    /**
     * The configuration specifying telemetry settings for the Dataproc Metastore service. If unspecified defaults to JSON.
     * Structure is documented below.
     */
    public val telemetryConfig: Output
        get() = javaResource.telemetryConfig().applyValue({ args0 ->
            args0.let({ args0 ->
                metastoreServiceTelemetryConfigToKotlin(args0)
            })
        })

    /**
     * The tier of the service.
     * Possible values are: `DEVELOPER`, `ENTERPRISE`.
     */
    public val tier: Output
        get() = javaResource.tier().applyValue({ args0 -> args0 })

    /**
     * The globally unique resource identifier of the metastore service.
     */
    public val uid: Output
        get() = javaResource.uid().applyValue({ args0 -> args0 })
}

public object MetastoreServiceMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.gcp.dataproc.MetastoreService::class == javaResource::class

    override fun map(javaResource: Resource): MetastoreService = MetastoreService(
        javaResource as
            com.pulumi.gcp.dataproc.MetastoreService,
    )
}

/**
 * @see [MetastoreService].
 * @param name The _unique_ name of the resulting resource.
 * @param block Builder for [MetastoreService].
 */
public suspend fun metastoreService(
    name: String,
    block: suspend MetastoreServiceResourceBuilder.() -> Unit,
): MetastoreService {
    val builder = MetastoreServiceResourceBuilder()
    builder.name(name)
    block(builder)
    return builder.build()
}

/**
 * @see [MetastoreService].
 * @param name The _unique_ name of the resulting resource.
 */
public fun metastoreService(name: String): MetastoreService {
    val builder = MetastoreServiceResourceBuilder()
    builder.name(name)
    return builder.build()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy