Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.pulumi.azure.relay.kotlin.NamespaceAuthorizationRule.kt Maven / Gradle / Ivy
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.azure.relay.kotlin
import com.pulumi.core.Output
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.String
import kotlin.Suppress
import kotlin.Unit
/**
* Builder for [NamespaceAuthorizationRule].
*/
@PulumiTagMarker
public class NamespaceAuthorizationRuleResourceBuilder internal constructor() {
public var name: String? = null
public var args: NamespaceAuthorizationRuleArgs = NamespaceAuthorizationRuleArgs()
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 NamespaceAuthorizationRuleArgsBuilder.() -> Unit) {
val builder = NamespaceAuthorizationRuleArgsBuilder()
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(): NamespaceAuthorizationRule {
val builtJavaResource =
com.pulumi.azure.relay.NamespaceAuthorizationRule(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return NamespaceAuthorizationRule(builtJavaResource)
}
}
/**
* Manages an Azure Relay Namespace Authorization Rule.
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as azure from "@pulumi/azure";
* const example = new azure.core.ResourceGroup("example", {
* name: "example-resources",
* location: "West Europe",
* });
* const exampleNamespace = new azure.relay.Namespace("example", {
* name: "example-relay",
* location: example.location,
* resourceGroupName: example.name,
* skuName: "Standard",
* tags: {
* source: "terraform",
* },
* });
* const exampleNamespaceAuthorizationRule = new azure.relay.NamespaceAuthorizationRule("example", {
* name: "example",
* resourceGroupName: example.name,
* namespaceName: exampleNamespace.name,
* listen: true,
* send: true,
* manage: false,
* });
* ```
* ```python
* import pulumi
* import pulumi_azure as azure
* example = azure.core.ResourceGroup("example",
* name="example-resources",
* location="West Europe")
* example_namespace = azure.relay.Namespace("example",
* name="example-relay",
* location=example.location,
* resource_group_name=example.name,
* sku_name="Standard",
* tags={
* "source": "terraform",
* })
* example_namespace_authorization_rule = azure.relay.NamespaceAuthorizationRule("example",
* name="example",
* resource_group_name=example.name,
* namespace_name=example_namespace.name,
* listen=True,
* send=True,
* manage=False)
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Azure = Pulumi.Azure;
* return await Deployment.RunAsync(() =>
* {
* var example = new Azure.Core.ResourceGroup("example", new()
* {
* Name = "example-resources",
* Location = "West Europe",
* });
* var exampleNamespace = new Azure.Relay.Namespace("example", new()
* {
* Name = "example-relay",
* Location = example.Location,
* ResourceGroupName = example.Name,
* SkuName = "Standard",
* Tags =
* {
* { "source", "terraform" },
* },
* });
* var exampleNamespaceAuthorizationRule = new Azure.Relay.NamespaceAuthorizationRule("example", new()
* {
* Name = "example",
* ResourceGroupName = example.Name,
* NamespaceName = exampleNamespace.Name,
* Listen = true,
* Send = true,
* Manage = false,
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/relay"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
* Name: pulumi.String("example-resources"),
* Location: pulumi.String("West Europe"),
* })
* if err != nil {
* return err
* }
* exampleNamespace, err := relay.NewNamespace(ctx, "example", &relay.NamespaceArgs{
* Name: pulumi.String("example-relay"),
* Location: example.Location,
* ResourceGroupName: example.Name,
* SkuName: pulumi.String("Standard"),
* Tags: pulumi.StringMap{
* "source": pulumi.String("terraform"),
* },
* })
* if err != nil {
* return err
* }
* _, err = relay.NewNamespaceAuthorizationRule(ctx, "example", &relay.NamespaceAuthorizationRuleArgs{
* Name: pulumi.String("example"),
* ResourceGroupName: example.Name,
* NamespaceName: exampleNamespace.Name,
* Listen: pulumi.Bool(true),
* Send: pulumi.Bool(true),
* Manage: pulumi.Bool(false),
* })
* 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.azure.core.ResourceGroup;
* import com.pulumi.azure.core.ResourceGroupArgs;
* import com.pulumi.azure.relay.Namespace;
* import com.pulumi.azure.relay.NamespaceArgs;
* import com.pulumi.azure.relay.NamespaceAuthorizationRule;
* import com.pulumi.azure.relay.NamespaceAuthorizationRuleArgs;
* 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 example = new ResourceGroup("example", ResourceGroupArgs.builder()
* .name("example-resources")
* .location("West Europe")
* .build());
* var exampleNamespace = new Namespace("exampleNamespace", NamespaceArgs.builder()
* .name("example-relay")
* .location(example.location())
* .resourceGroupName(example.name())
* .skuName("Standard")
* .tags(Map.of("source", "terraform"))
* .build());
* var exampleNamespaceAuthorizationRule = new NamespaceAuthorizationRule("exampleNamespaceAuthorizationRule", NamespaceAuthorizationRuleArgs.builder()
* .name("example")
* .resourceGroupName(example.name())
* .namespaceName(exampleNamespace.name())
* .listen(true)
* .send(true)
* .manage(false)
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: azure:core:ResourceGroup
* properties:
* name: example-resources
* location: West Europe
* exampleNamespace:
* type: azure:relay:Namespace
* name: example
* properties:
* name: example-relay
* location: ${example.location}
* resourceGroupName: ${example.name}
* skuName: Standard
* tags:
* source: terraform
* exampleNamespaceAuthorizationRule:
* type: azure:relay:NamespaceAuthorizationRule
* name: example
* properties:
* name: example
* resourceGroupName: ${example.name}
* namespaceName: ${exampleNamespace.name}
* listen: true
* send: true
* manage: false
* ```
*
* ## Import
* Azure Relay Namespace Authorization Rules can be imported using the `resource id`, e.g.
* ```sh
* $ pulumi import azure:relay/namespaceAuthorizationRule:NamespaceAuthorizationRule example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/group1/providers/Microsoft.Relay/namespaces/namespace1/authorizationRules/rule1
* ```
*/
public class NamespaceAuthorizationRule internal constructor(
override val javaResource: com.pulumi.azure.relay.NamespaceAuthorizationRule,
) : KotlinCustomResource(javaResource, NamespaceAuthorizationRuleMapper) {
/**
* Grants listen access to this Authorization Rule. Defaults to `false`.
*/
public val listen: Output?
get() = javaResource.listen().applyValue({ args0 -> args0.map({ args0 -> args0 }).orElse(null) })
/**
* Grants manage access to this Authorization Rule. When this property is `true` - both `listen` and `send` must be set to `true` too. Defaults to `false`.
*/
public val manage: Output?
get() = javaResource.manage().applyValue({ args0 -> args0.map({ args0 -> args0 }).orElse(null) })
/**
* The name which should be used for this Azure Relay Namespace Authorization Rule. Changing this forces a new Azure Relay Namespace Authorization Rule to be created.
*/
public val name: Output
get() = javaResource.name().applyValue({ args0 -> args0 })
/**
* Name of the Azure Relay Namespace for which this Azure Relay Namespace Authorization Rule will be created. Changing this forces a new Azure Relay Namespace Authorization Rule to be created.
*/
public val namespaceName: Output
get() = javaResource.namespaceName().applyValue({ args0 -> args0 })
/**
* The Primary Connection String for the Azure Relay Namespace Authorization Rule.
*/
public val primaryConnectionString: Output
get() = javaResource.primaryConnectionString().applyValue({ args0 -> args0 })
/**
* The Primary Key for the Azure Relay Namespace Authorization Rule.
*/
public val primaryKey: Output
get() = javaResource.primaryKey().applyValue({ args0 -> args0 })
/**
* The name of the Resource Group where the Azure Relay Namespace Authorization Rule should exist. Changing this forces a new Azure Relay Namespace Authorization Rule to be created.
*/
public val resourceGroupName: Output
get() = javaResource.resourceGroupName().applyValue({ args0 -> args0 })
/**
* The Secondary Connection String for the Azure Relay Namespace Authorization Rule.
*/
public val secondaryConnectionString: Output
get() = javaResource.secondaryConnectionString().applyValue({ args0 -> args0 })
/**
* The Secondary Key for the Azure Relay Namespace Authorization Rule.
*/
public val secondaryKey: Output
get() = javaResource.secondaryKey().applyValue({ args0 -> args0 })
/**
* Grants send access to this Authorization Rule. Defaults to `false`.
*/
public val send: Output?
get() = javaResource.send().applyValue({ args0 -> args0.map({ args0 -> args0 }).orElse(null) })
}
public object NamespaceAuthorizationRuleMapper : ResourceMapper {
override fun supportsMappingOfType(javaResource: Resource): Boolean =
com.pulumi.azure.relay.NamespaceAuthorizationRule::class == javaResource::class
override fun map(javaResource: Resource): NamespaceAuthorizationRule =
NamespaceAuthorizationRule(javaResource as com.pulumi.azure.relay.NamespaceAuthorizationRule)
}
/**
* @see [NamespaceAuthorizationRule].
* @param name The _unique_ name of the resulting resource.
* @param block Builder for [NamespaceAuthorizationRule].
*/
public suspend fun namespaceAuthorizationRule(
name: String,
block: suspend NamespaceAuthorizationRuleResourceBuilder.() -> Unit,
): NamespaceAuthorizationRule {
val builder = NamespaceAuthorizationRuleResourceBuilder()
builder.name(name)
block(builder)
return builder.build()
}
/**
* @see [NamespaceAuthorizationRule].
* @param name The _unique_ name of the resulting resource.
*/
public fun namespaceAuthorizationRule(name: String): NamespaceAuthorizationRule {
val builder = NamespaceAuthorizationRuleResourceBuilder()
builder.name(name)
return builder.build()
}