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

com.pulumi.azure.managedapplication.kotlin.Application.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: 6.21.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.azure.managedapplication.kotlin

import com.pulumi.azure.managedapplication.kotlin.outputs.ApplicationPlan
import com.pulumi.azure.managedapplication.kotlin.outputs.ApplicationPlan.Companion.toKotlin
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.Deprecated
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.Map

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

    public var args: ApplicationArgs = ApplicationArgs()

    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 ApplicationArgsBuilder.() -> Unit) {
        val builder = ApplicationArgsBuilder()
        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(): Application {
        val builtJavaResource = com.pulumi.azure.managedapplication.Application(
            this.name,
            this.args.toJava(),
            this.opts.toJava(),
        )
        return Application(builtJavaResource)
    }
}

/**
 * Manages a Managed Application.
 * ## Example Usage
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as azure from "@pulumi/azure";
 * import * as std from "@pulumi/std";
 * const current = azure.core.getClientConfig({});
 * const builtin = azure.authorization.getRoleDefinition({
 *     name: "Contributor",
 * });
 * const example = new azure.core.ResourceGroup("example", {
 *     name: "example-resources",
 *     location: "West Europe",
 * });
 * const exampleDefinition = new azure.managedapplication.Definition("example", {
 *     name: "examplemanagedapplicationdefinition",
 *     location: example.location,
 *     resourceGroupName: example.name,
 *     lockLevel: "ReadOnly",
 *     packageFileUri: "https://github.com/Azure/azure-managedapp-samples/raw/master/Managed Application Sample Packages/201-managed-storage-account/managedstorage.zip",
 *     displayName: "TestManagedAppDefinition",
 *     description: "Test Managed App Definition",
 *     authorizations: [{
 *         servicePrincipalId: current.then(current => current.objectId),
 *         roleDefinitionId: Promise.all([builtin.then(builtin => std.split({
 *             separator: "/",
 *             text: builtin.id,
 *         })), builtin.then(builtin => std.split({
 *             separator: "/",
 *             text: builtin.id,
 *         })).then(invoke => invoke.result).length]).then(([invoke, length]) => invoke.result[length - 1]),
 *     }],
 * });
 * const exampleApplication = new azure.managedapplication.Application("example", {
 *     name: "example-managedapplication",
 *     location: example.location,
 *     resourceGroupName: example.name,
 *     kind: "ServiceCatalog",
 *     managedResourceGroupName: "infrastructureGroup",
 *     applicationDefinitionId: exampleDefinition.id,
 *     parameterValues: pulumi.jsonStringify({
 *         location: {
 *             value: example.location,
 *         },
 *         storageAccountNamePrefix: {
 *             value: "storeNamePrefix",
 *         },
 *         storageAccountType: {
 *             value: "Standard_LRS",
 *         },
 *     }),
 * });
 * ```
 * ```python
 * import pulumi
 * import json
 * import pulumi_azure as azure
 * import pulumi_std as std
 * current = azure.core.get_client_config()
 * builtin = azure.authorization.get_role_definition(name="Contributor")
 * example = azure.core.ResourceGroup("example",
 *     name="example-resources",
 *     location="West Europe")
 * example_definition = azure.managedapplication.Definition("example",
 *     name="examplemanagedapplicationdefinition",
 *     location=example.location,
 *     resource_group_name=example.name,
 *     lock_level="ReadOnly",
 *     package_file_uri="https://github.com/Azure/azure-managedapp-samples/raw/master/Managed Application Sample Packages/201-managed-storage-account/managedstorage.zip",
 *     display_name="TestManagedAppDefinition",
 *     description="Test Managed App Definition",
 *     authorizations=[{
 *         "service_principal_id": current.object_id,
 *         "role_definition_id": std.split(separator="/",
 *             text=builtin.id).result[len(std.split(separator="/",
 *             text=builtin.id).result) - 1],
 *     }])
 * example_application = azure.managedapplication.Application("example",
 *     name="example-managedapplication",
 *     location=example.location,
 *     resource_group_name=example.name,
 *     kind="ServiceCatalog",
 *     managed_resource_group_name="infrastructureGroup",
 *     application_definition_id=example_definition.id,
 *     parameter_values=pulumi.Output.json_dumps({
 *         "location": {
 *             "value": example.location,
 *         },
 *         "storageAccountNamePrefix": {
 *             "value": "storeNamePrefix",
 *         },
 *         "storageAccountType": {
 *             "value": "Standard_LRS",
 *         },
 *     }))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using System.Text.Json;
 * using Pulumi;
 * using Azure = Pulumi.Azure;
 * using Std = Pulumi.Std;
 * return await Deployment.RunAsync(() =>
 * {
 *     var current = Azure.Core.GetClientConfig.Invoke();
 *     var builtin = Azure.Authorization.GetRoleDefinition.Invoke(new()
 *     {
 *         Name = "Contributor",
 *     });
 *     var example = new Azure.Core.ResourceGroup("example", new()
 *     {
 *         Name = "example-resources",
 *         Location = "West Europe",
 *     });
 *     var exampleDefinition = new Azure.ManagedApplication.Definition("example", new()
 *     {
 *         Name = "examplemanagedapplicationdefinition",
 *         Location = example.Location,
 *         ResourceGroupName = example.Name,
 *         LockLevel = "ReadOnly",
 *         PackageFileUri = "https://github.com/Azure/azure-managedapp-samples/raw/master/Managed Application Sample Packages/201-managed-storage-account/managedstorage.zip",
 *         DisplayName = "TestManagedAppDefinition",
 *         Description = "Test Managed App Definition",
 *         Authorizations = new[]
 *         {
 *             new Azure.ManagedApplication.Inputs.DefinitionAuthorizationArgs
 *             {
 *                 ServicePrincipalId = current.Apply(getClientConfigResult => getClientConfigResult.ObjectId),
 *                 RoleDefinitionId = Output.Tuple(Std.Split.Invoke(new()
 *                 {
 *                     Separator = "/",
 *                     Text = builtin.Apply(getRoleDefinitionResult => getRoleDefinitionResult.Id),
 *                 }), Std.Split.Invoke(new()
 *                 {
 *                     Separator = "/",
 *                     Text = builtin.Apply(getRoleDefinitionResult => getRoleDefinitionResult.Id),
 *                 }).Apply(invoke => invoke.Result).Length).Apply(values =>
 *                 {
 *                     var invoke = values.Item1;
 *                     var length = values.Item2;
 *                     return invoke.Result[length - 1];
 *                 }),
 *             },
 *         },
 *     });
 *     var exampleApplication = new Azure.ManagedApplication.Application("example", new()
 *     {
 *         Name = "example-managedapplication",
 *         Location = example.Location,
 *         ResourceGroupName = example.Name,
 *         Kind = "ServiceCatalog",
 *         ManagedResourceGroupName = "infrastructureGroup",
 *         ApplicationDefinitionId = exampleDefinition.Id,
 *         ParameterValues = Output.JsonSerialize(Output.Create(new Dictionary
 *         {
 *             ["location"] = new Dictionary
 *             {
 *                 ["value"] = example.Location,
 *             },
 *             ["storageAccountNamePrefix"] = new Dictionary
 *             {
 *                 ["value"] = "storeNamePrefix",
 *             },
 *             ["storageAccountType"] = new Dictionary
 *             {
 *                 ["value"] = "Standard_LRS",
 *             },
 *         })),
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"encoding/json"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/authorization"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/managedapplication"
 * 	"github.com/pulumi/pulumi-std/sdk/go/std"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		current, err := core.GetClientConfig(ctx, nil, nil)
 * 		if err != nil {
 * 			return err
 * 		}
 * 		builtin, err := authorization.LookupRoleDefinition(ctx, &authorization.LookupRoleDefinitionArgs{
 * 			Name: pulumi.StringRef("Contributor"),
 * 		}, nil)
 * 		if err != nil {
 * 			return err
 * 		}
 * 		example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
 * 			Name:     pulumi.String("example-resources"),
 * 			Location: pulumi.String("West Europe"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		invokeSplit, err := std.Split(ctx, &std.SplitArgs{
 * 			Separator: "/",
 * 			Text:      builtin.Id,
 * 		}, nil)
 * 		if err != nil {
 * 			return err
 * 		}
 * 		invokeSplit1, err := std.Split(ctx, &std.SplitArgs{
 * 			Separator: "/",
 * 			Text:      builtin.Id,
 * 		}, nil)
 * 		if err != nil {
 * 			return err
 * 		}
 * 		exampleDefinition, err := managedapplication.NewDefinition(ctx, "example", &managedapplication.DefinitionArgs{
 * 			Name:              pulumi.String("examplemanagedapplicationdefinition"),
 * 			Location:          example.Location,
 * 			ResourceGroupName: example.Name,
 * 			LockLevel:         pulumi.String("ReadOnly"),
 * 			PackageFileUri:    pulumi.String("https://github.com/Azure/azure-managedapp-samples/raw/master/Managed Application Sample Packages/201-managed-storage-account/managedstorage.zip"),
 * 			DisplayName:       pulumi.String("TestManagedAppDefinition"),
 * 			Description:       pulumi.String("Test Managed App Definition"),
 * 			Authorizations: managedapplication.DefinitionAuthorizationArray{
 * 				&managedapplication.DefinitionAuthorizationArgs{
 * 					ServicePrincipalId: pulumi.String(current.ObjectId),
 * 					RoleDefinitionId:   pulumi.String(invokeSplit.Result[float64(pulumi.Float64(len(invokeSplit1.Result))-1)]),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = managedapplication.NewApplication(ctx, "example", &managedapplication.ApplicationArgs{
 * 			Name:                     pulumi.String("example-managedapplication"),
 * 			Location:                 example.Location,
 * 			ResourceGroupName:        example.Name,
 * 			Kind:                     pulumi.String("ServiceCatalog"),
 * 			ManagedResourceGroupName: pulumi.String("infrastructureGroup"),
 * 			ApplicationDefinitionId:  exampleDefinition.ID(),
 * 			ParameterValues: example.Location.ApplyT(func(location string) (pulumi.String, error) {
 * 				var _zero pulumi.String
 * 				tmpJSON0, err := json.Marshal(map[string]interface{}{
 * 					"location": map[string]interface{}{
 * 						"value": location,
 * 					},
 * 					"storageAccountNamePrefix": map[string]interface{}{
 * 						"value": "storeNamePrefix",
 * 					},
 * 					"storageAccountType": map[string]interface{}{
 * 						"value": "Standard_LRS",
 * 					},
 * 				})
 * 				if err != nil {
 * 					return _zero, err
 * 				}
 * 				json0 := string(tmpJSON0)
 * 				return pulumi.String(json0), nil
 * 			}).(pulumi.StringOutput),
 * 		})
 * 		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.CoreFunctions;
 * import com.pulumi.azure.authorization.AuthorizationFunctions;
 * import com.pulumi.azure.authorization.inputs.GetRoleDefinitionArgs;
 * import com.pulumi.azure.core.ResourceGroup;
 * import com.pulumi.azure.core.ResourceGroupArgs;
 * import com.pulumi.azure.managedapplication.Definition;
 * import com.pulumi.azure.managedapplication.DefinitionArgs;
 * import com.pulumi.azure.managedapplication.inputs.DefinitionAuthorizationArgs;
 * import com.pulumi.azure.managedapplication.Application;
 * import com.pulumi.azure.managedapplication.ApplicationArgs;
 * import static com.pulumi.codegen.internal.Serialization.*;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         final var current = CoreFunctions.getClientConfig();
 *         final var builtin = AuthorizationFunctions.getRoleDefinition(GetRoleDefinitionArgs.builder()
 *             .name("Contributor")
 *             .build());
 *         var example = new ResourceGroup("example", ResourceGroupArgs.builder()
 *             .name("example-resources")
 *             .location("West Europe")
 *             .build());
 *         var exampleDefinition = new Definition("exampleDefinition", DefinitionArgs.builder()
 *             .name("examplemanagedapplicationdefinition")
 *             .location(example.location())
 *             .resourceGroupName(example.name())
 *             .lockLevel("ReadOnly")
 *             .packageFileUri("https://github.com/Azure/azure-managedapp-samples/raw/master/Managed Application Sample Packages/201-managed-storage-account/managedstorage.zip")
 *             .displayName("TestManagedAppDefinition")
 *             .description("Test Managed App Definition")
 *             .authorizations(DefinitionAuthorizationArgs.builder()
 *                 .servicePrincipalId(current.applyValue(getClientConfigResult -> getClientConfigResult.objectId()))
 *                 .roleDefinitionId(StdFunctions.split(SplitArgs.builder()
 *                     .separator("/")
 *                     .text(builtin.applyValue(getRoleDefinitionResult -> getRoleDefinitionResult.id()))
 *                     .build()).result()[StdFunctions.split(SplitArgs.builder()
 *                     .separator("/")
 *                     .text(builtin.applyValue(getRoleDefinitionResult -> getRoleDefinitionResult.id()))
 *                     .build()).result().length() - 1])
 *                 .build())
 *             .build());
 *         var exampleApplication = new Application("exampleApplication", ApplicationArgs.builder()
 *             .name("example-managedapplication")
 *             .location(example.location())
 *             .resourceGroupName(example.name())
 *             .kind("ServiceCatalog")
 *             .managedResourceGroupName("infrastructureGroup")
 *             .applicationDefinitionId(exampleDefinition.id())
 *             .parameterValues(example.location().applyValue(location -> serializeJson(
 *                 jsonObject(
 *                     jsonProperty("location", jsonObject(
 *                         jsonProperty("value", location)
 *                     )),
 *                     jsonProperty("storageAccountNamePrefix", jsonObject(
 *                         jsonProperty("value", "storeNamePrefix")
 *                     )),
 *                     jsonProperty("storageAccountType", jsonObject(
 *                         jsonProperty("value", "Standard_LRS")
 *                     ))
 *                 ))))
 *             .build());
 *     }
 * }
 * ```
 * 
 * ## Import
 * Managed Application can be imported using the `resource id`, e.g.
 * ```sh
 * $ pulumi import azure:managedapplication/application:Application example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/group1/providers/Microsoft.Solutions/applications/app1
 * ```
 */
public class Application internal constructor(
    override val javaResource: com.pulumi.azure.managedapplication.Application,
) : KotlinCustomResource(javaResource, ApplicationMapper) {
    /**
     * The application definition ID to deploy.
     */
    public val applicationDefinitionId: Output?
        get() = javaResource.applicationDefinitionId().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * The kind of the managed application to deploy. Possible values are `MarketPlace` and `ServiceCatalog`. Changing this forces a new resource to be created.
     */
    public val kind: Output
        get() = javaResource.kind().applyValue({ args0 -> args0 })

    /**
     * Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
     */
    public val location: Output
        get() = javaResource.location().applyValue({ args0 -> args0 })

    /**
     * The name of the target resource group where all the resources deployed by the managed application will reside. Changing this forces a new resource to be created.
     */
    public val managedResourceGroupName: Output
        get() = javaResource.managedResourceGroupName().applyValue({ args0 -> args0 })

    /**
     * Specifies the name of the Managed Application. Changing this forces a new resource to be created.
     */
    public val name: Output
        get() = javaResource.name().applyValue({ args0 -> args0 })

    /**
     * The name and value pairs that define the managed application outputs.
     */
    public val outputs: Output>
        get() = javaResource.outputs().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * The parameter values to pass to the Managed Application. This field is a JSON object that allows you to assign parameters to this Managed Application.
     */
    public val parameterValues: Output
        get() = javaResource.parameterValues().applyValue({ args0 -> args0 })

    /**
     * A mapping of name and value pairs to pass to the managed application as parameters.
     * > **NOTE:** `parameters` only supports values with `string` or `secureString` type and will be deprecated in version 4.0 of the provider - please use `parameter_values` instead which supports more parameter types.
     */
    @Deprecated(
        message = """
  This property has been deprecated in favour of `parameter_values`
  """,
    )
    public val parameters: Output>
        get() = javaResource.parameters().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * One `plan` block as defined below. Changing this forces a new resource to be created.
     */
    public val plan: Output?
        get() = javaResource.plan().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    toKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * The name of the Resource Group where the Managed Application should exist. Changing this forces a new resource to be created.
     */
    public val resourceGroupName: Output
        get() = javaResource.resourceGroupName().applyValue({ args0 -> args0 })

    /**
     * A mapping of tags to assign to the resource.
     */
    public val tags: Output>?
        get() = javaResource.tags().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.key.to(args0.value)
                }).toMap()
            }).orElse(null)
        })
}

public object ApplicationMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.azure.managedapplication.Application::class == javaResource::class

    override fun map(javaResource: Resource): Application = Application(
        javaResource as
            com.pulumi.azure.managedapplication.Application,
    )
}

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

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




© 2015 - 2025 Weber Informatics LLC | Privacy Policy