com.pulumi.azure.policy.kotlin.VirtualMachineConfigurationAssignment.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-azure-kotlin Show documentation
Show all versions of pulumi-azure-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.azure.policy.kotlin
import com.pulumi.azure.policy.kotlin.outputs.VirtualMachineConfigurationAssignmentConfiguration
import com.pulumi.azure.policy.kotlin.outputs.VirtualMachineConfigurationAssignmentConfiguration.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.String
import kotlin.Suppress
import kotlin.Unit
/**
* Builder for [VirtualMachineConfigurationAssignment].
*/
@PulumiTagMarker
public class VirtualMachineConfigurationAssignmentResourceBuilder internal constructor() {
public var name: String? = null
public var args: VirtualMachineConfigurationAssignmentArgs =
VirtualMachineConfigurationAssignmentArgs()
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 VirtualMachineConfigurationAssignmentArgsBuilder.() -> Unit) {
val builder = VirtualMachineConfigurationAssignmentArgsBuilder()
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(): VirtualMachineConfigurationAssignment {
val builtJavaResource =
com.pulumi.azure.policy.VirtualMachineConfigurationAssignment(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return VirtualMachineConfigurationAssignment(builtJavaResource)
}
}
/**
* Applies a Guest Configuration Policy to a Virtual Machine.
* > **NOTE:** You can create Guest Configuration Policies without defining a `azure.compute.Extension` resource, however the policies will not be executed until a `azure.compute.Extension` has been provisioned to the virtual machine.
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as azure from "@pulumi/azure";
* const example = new azure.core.ResourceGroup("example", {
* name: "example-gca",
* location: "West Europe",
* });
* const exampleVirtualNetwork = new azure.network.VirtualNetwork("example", {
* name: "example-vnet",
* location: example.location,
* resourceGroupName: example.name,
* addressSpaces: ["10.0.0.0/16"],
* });
* const exampleSubnet = new azure.network.Subnet("example", {
* name: "internal",
* resourceGroupName: example.name,
* virtualNetworkName: exampleVirtualNetwork.name,
* addressPrefixes: ["10.0.2.0/24"],
* });
* const exampleNetworkInterface = new azure.network.NetworkInterface("example", {
* name: "example-nic",
* resourceGroupName: example.name,
* location: example.location,
* ipConfigurations: [{
* name: "internal",
* subnetId: exampleSubnet.id,
* privateIpAddressAllocation: "Dynamic",
* }],
* });
* const exampleWindowsVirtualMachine = new azure.compute.WindowsVirtualMachine("example", {
* name: "examplevm",
* resourceGroupName: example.name,
* location: example.location,
* size: "Standard_F2",
* adminUsername: "adminuser",
* adminPassword: "P@$$w0rd1234!",
* networkInterfaceIds: [exampleNetworkInterface.id],
* identity: {
* type: "SystemAssigned",
* },
* osDisk: {
* caching: "ReadWrite",
* storageAccountType: "Standard_LRS",
* },
* sourceImageReference: {
* publisher: "MicrosoftWindowsServer",
* offer: "WindowsServer",
* sku: "2019-Datacenter",
* version: "latest",
* },
* });
* const exampleExtension = new azure.compute.Extension("example", {
* name: "AzurePolicyforWindows",
* virtualMachineId: exampleWindowsVirtualMachine.id,
* publisher: "Microsoft.GuestConfiguration",
* type: "ConfigurationforWindows",
* typeHandlerVersion: "1.29",
* autoUpgradeMinorVersion: true,
* });
* const exampleVirtualMachineConfigurationAssignment = new azure.policy.VirtualMachineConfigurationAssignment("example", {
* name: "AzureWindowsBaseline",
* location: exampleWindowsVirtualMachine.location,
* virtualMachineId: exampleWindowsVirtualMachine.id,
* configuration: {
* assignmentType: "ApplyAndMonitor",
* version: "1.*",
* parameters: [
* {
* name: "Minimum Password Length;ExpectedValue",
* value: "16",
* },
* {
* name: "Minimum Password Age;ExpectedValue",
* value: "0",
* },
* {
* name: "Maximum Password Age;ExpectedValue",
* value: "30,45",
* },
* {
* name: "Enforce Password History;ExpectedValue",
* value: "10",
* },
* {
* name: "Password Must Meet Complexity Requirements;ExpectedValue",
* value: "1",
* },
* ],
* },
* });
* ```
* ```python
* import pulumi
* import pulumi_azure as azure
* example = azure.core.ResourceGroup("example",
* name="example-gca",
* location="West Europe")
* example_virtual_network = azure.network.VirtualNetwork("example",
* name="example-vnet",
* location=example.location,
* resource_group_name=example.name,
* address_spaces=["10.0.0.0/16"])
* example_subnet = azure.network.Subnet("example",
* name="internal",
* resource_group_name=example.name,
* virtual_network_name=example_virtual_network.name,
* address_prefixes=["10.0.2.0/24"])
* example_network_interface = azure.network.NetworkInterface("example",
* name="example-nic",
* resource_group_name=example.name,
* location=example.location,
* ip_configurations=[azure.network.NetworkInterfaceIpConfigurationArgs(
* name="internal",
* subnet_id=example_subnet.id,
* private_ip_address_allocation="Dynamic",
* )])
* example_windows_virtual_machine = azure.compute.WindowsVirtualMachine("example",
* name="examplevm",
* resource_group_name=example.name,
* location=example.location,
* size="Standard_F2",
* admin_username="adminuser",
* admin_password="P@$$w0rd1234!",
* network_interface_ids=[example_network_interface.id],
* identity=azure.compute.WindowsVirtualMachineIdentityArgs(
* type="SystemAssigned",
* ),
* os_disk=azure.compute.WindowsVirtualMachineOsDiskArgs(
* caching="ReadWrite",
* storage_account_type="Standard_LRS",
* ),
* source_image_reference=azure.compute.WindowsVirtualMachineSourceImageReferenceArgs(
* publisher="MicrosoftWindowsServer",
* offer="WindowsServer",
* sku="2019-Datacenter",
* version="latest",
* ))
* example_extension = azure.compute.Extension("example",
* name="AzurePolicyforWindows",
* virtual_machine_id=example_windows_virtual_machine.id,
* publisher="Microsoft.GuestConfiguration",
* type="ConfigurationforWindows",
* type_handler_version="1.29",
* auto_upgrade_minor_version=True)
* example_virtual_machine_configuration_assignment = azure.policy.VirtualMachineConfigurationAssignment("example",
* name="AzureWindowsBaseline",
* location=example_windows_virtual_machine.location,
* virtual_machine_id=example_windows_virtual_machine.id,
* configuration=azure.policy.VirtualMachineConfigurationAssignmentConfigurationArgs(
* assignment_type="ApplyAndMonitor",
* version="1.*",
* parameters=[
* azure.policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs(
* name="Minimum Password Length;ExpectedValue",
* value="16",
* ),
* azure.policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs(
* name="Minimum Password Age;ExpectedValue",
* value="0",
* ),
* azure.policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs(
* name="Maximum Password Age;ExpectedValue",
* value="30,45",
* ),
* azure.policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs(
* name="Enforce Password History;ExpectedValue",
* value="10",
* ),
* azure.policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs(
* name="Password Must Meet Complexity Requirements;ExpectedValue",
* value="1",
* ),
* ],
* ))
* ```
* ```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-gca",
* Location = "West Europe",
* });
* var exampleVirtualNetwork = new Azure.Network.VirtualNetwork("example", new()
* {
* Name = "example-vnet",
* Location = example.Location,
* ResourceGroupName = example.Name,
* AddressSpaces = new[]
* {
* "10.0.0.0/16",
* },
* });
* var exampleSubnet = new Azure.Network.Subnet("example", new()
* {
* Name = "internal",
* ResourceGroupName = example.Name,
* VirtualNetworkName = exampleVirtualNetwork.Name,
* AddressPrefixes = new[]
* {
* "10.0.2.0/24",
* },
* });
* var exampleNetworkInterface = new Azure.Network.NetworkInterface("example", new()
* {
* Name = "example-nic",
* ResourceGroupName = example.Name,
* Location = example.Location,
* IpConfigurations = new[]
* {
* new Azure.Network.Inputs.NetworkInterfaceIpConfigurationArgs
* {
* Name = "internal",
* SubnetId = exampleSubnet.Id,
* PrivateIpAddressAllocation = "Dynamic",
* },
* },
* });
* var exampleWindowsVirtualMachine = new Azure.Compute.WindowsVirtualMachine("example", new()
* {
* Name = "examplevm",
* ResourceGroupName = example.Name,
* Location = example.Location,
* Size = "Standard_F2",
* AdminUsername = "adminuser",
* AdminPassword = "P@$$w0rd1234!",
* NetworkInterfaceIds = new[]
* {
* exampleNetworkInterface.Id,
* },
* Identity = new Azure.Compute.Inputs.WindowsVirtualMachineIdentityArgs
* {
* Type = "SystemAssigned",
* },
* OsDisk = new Azure.Compute.Inputs.WindowsVirtualMachineOsDiskArgs
* {
* Caching = "ReadWrite",
* StorageAccountType = "Standard_LRS",
* },
* SourceImageReference = new Azure.Compute.Inputs.WindowsVirtualMachineSourceImageReferenceArgs
* {
* Publisher = "MicrosoftWindowsServer",
* Offer = "WindowsServer",
* Sku = "2019-Datacenter",
* Version = "latest",
* },
* });
* var exampleExtension = new Azure.Compute.Extension("example", new()
* {
* Name = "AzurePolicyforWindows",
* VirtualMachineId = exampleWindowsVirtualMachine.Id,
* Publisher = "Microsoft.GuestConfiguration",
* Type = "ConfigurationforWindows",
* TypeHandlerVersion = "1.29",
* AutoUpgradeMinorVersion = true,
* });
* var exampleVirtualMachineConfigurationAssignment = new Azure.Policy.VirtualMachineConfigurationAssignment("example", new()
* {
* Name = "AzureWindowsBaseline",
* Location = exampleWindowsVirtualMachine.Location,
* VirtualMachineId = exampleWindowsVirtualMachine.Id,
* Configuration = new Azure.Policy.Inputs.VirtualMachineConfigurationAssignmentConfigurationArgs
* {
* AssignmentType = "ApplyAndMonitor",
* Version = "1.*",
* Parameters = new[]
* {
* new Azure.Policy.Inputs.VirtualMachineConfigurationAssignmentConfigurationParameterArgs
* {
* Name = "Minimum Password Length;ExpectedValue",
* Value = "16",
* },
* new Azure.Policy.Inputs.VirtualMachineConfigurationAssignmentConfigurationParameterArgs
* {
* Name = "Minimum Password Age;ExpectedValue",
* Value = "0",
* },
* new Azure.Policy.Inputs.VirtualMachineConfigurationAssignmentConfigurationParameterArgs
* {
* Name = "Maximum Password Age;ExpectedValue",
* Value = "30,45",
* },
* new Azure.Policy.Inputs.VirtualMachineConfigurationAssignmentConfigurationParameterArgs
* {
* Name = "Enforce Password History;ExpectedValue",
* Value = "10",
* },
* new Azure.Policy.Inputs.VirtualMachineConfigurationAssignmentConfigurationParameterArgs
* {
* Name = "Password Must Meet Complexity Requirements;ExpectedValue",
* Value = "1",
* },
* },
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/compute"
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/network"
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/policy"
* "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-gca"),
* Location: pulumi.String("West Europe"),
* })
* if err != nil {
* return err
* }
* exampleVirtualNetwork, err := network.NewVirtualNetwork(ctx, "example", &network.VirtualNetworkArgs{
* Name: pulumi.String("example-vnet"),
* Location: example.Location,
* ResourceGroupName: example.Name,
* AddressSpaces: pulumi.StringArray{
* pulumi.String("10.0.0.0/16"),
* },
* })
* if err != nil {
* return err
* }
* exampleSubnet, err := network.NewSubnet(ctx, "example", &network.SubnetArgs{
* Name: pulumi.String("internal"),
* ResourceGroupName: example.Name,
* VirtualNetworkName: exampleVirtualNetwork.Name,
* AddressPrefixes: pulumi.StringArray{
* pulumi.String("10.0.2.0/24"),
* },
* })
* if err != nil {
* return err
* }
* exampleNetworkInterface, err := network.NewNetworkInterface(ctx, "example", &network.NetworkInterfaceArgs{
* Name: pulumi.String("example-nic"),
* ResourceGroupName: example.Name,
* Location: example.Location,
* IpConfigurations: network.NetworkInterfaceIpConfigurationArray{
* &network.NetworkInterfaceIpConfigurationArgs{
* Name: pulumi.String("internal"),
* SubnetId: exampleSubnet.ID(),
* PrivateIpAddressAllocation: pulumi.String("Dynamic"),
* },
* },
* })
* if err != nil {
* return err
* }
* exampleWindowsVirtualMachine, err := compute.NewWindowsVirtualMachine(ctx, "example", &compute.WindowsVirtualMachineArgs{
* Name: pulumi.String("examplevm"),
* ResourceGroupName: example.Name,
* Location: example.Location,
* Size: pulumi.String("Standard_F2"),
* AdminUsername: pulumi.String("adminuser"),
* AdminPassword: pulumi.String("P@$$w0rd1234!"),
* NetworkInterfaceIds: pulumi.StringArray{
* exampleNetworkInterface.ID(),
* },
* Identity: &compute.WindowsVirtualMachineIdentityArgs{
* Type: pulumi.String("SystemAssigned"),
* },
* OsDisk: &compute.WindowsVirtualMachineOsDiskArgs{
* Caching: pulumi.String("ReadWrite"),
* StorageAccountType: pulumi.String("Standard_LRS"),
* },
* SourceImageReference: &compute.WindowsVirtualMachineSourceImageReferenceArgs{
* Publisher: pulumi.String("MicrosoftWindowsServer"),
* Offer: pulumi.String("WindowsServer"),
* Sku: pulumi.String("2019-Datacenter"),
* Version: pulumi.String("latest"),
* },
* })
* if err != nil {
* return err
* }
* _, err = compute.NewExtension(ctx, "example", &compute.ExtensionArgs{
* Name: pulumi.String("AzurePolicyforWindows"),
* VirtualMachineId: exampleWindowsVirtualMachine.ID(),
* Publisher: pulumi.String("Microsoft.GuestConfiguration"),
* Type: pulumi.String("ConfigurationforWindows"),
* TypeHandlerVersion: pulumi.String("1.29"),
* AutoUpgradeMinorVersion: pulumi.Bool(true),
* })
* if err != nil {
* return err
* }
* _, err = policy.NewVirtualMachineConfigurationAssignment(ctx, "example", &policy.VirtualMachineConfigurationAssignmentArgs{
* Name: pulumi.String("AzureWindowsBaseline"),
* Location: exampleWindowsVirtualMachine.Location,
* VirtualMachineId: exampleWindowsVirtualMachine.ID(),
* Configuration: &policy.VirtualMachineConfigurationAssignmentConfigurationArgs{
* AssignmentType: pulumi.String("ApplyAndMonitor"),
* Version: pulumi.String("1.*"),
* Parameters: policy.VirtualMachineConfigurationAssignmentConfigurationParameterArray{
* &policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs{
* Name: pulumi.String("Minimum Password Length;ExpectedValue"),
* Value: pulumi.String("16"),
* },
* &policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs{
* Name: pulumi.String("Minimum Password Age;ExpectedValue"),
* Value: pulumi.String("0"),
* },
* &policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs{
* Name: pulumi.String("Maximum Password Age;ExpectedValue"),
* Value: pulumi.String("30,45"),
* },
* &policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs{
* Name: pulumi.String("Enforce Password History;ExpectedValue"),
* Value: pulumi.String("10"),
* },
* &policy.VirtualMachineConfigurationAssignmentConfigurationParameterArgs{
* Name: pulumi.String("Password Must Meet Complexity Requirements;ExpectedValue"),
* Value: pulumi.String("1"),
* },
* },
* },
* })
* 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.network.VirtualNetwork;
* import com.pulumi.azure.network.VirtualNetworkArgs;
* import com.pulumi.azure.network.Subnet;
* import com.pulumi.azure.network.SubnetArgs;
* import com.pulumi.azure.network.NetworkInterface;
* import com.pulumi.azure.network.NetworkInterfaceArgs;
* import com.pulumi.azure.network.inputs.NetworkInterfaceIpConfigurationArgs;
* import com.pulumi.azure.compute.WindowsVirtualMachine;
* import com.pulumi.azure.compute.WindowsVirtualMachineArgs;
* import com.pulumi.azure.compute.inputs.WindowsVirtualMachineIdentityArgs;
* import com.pulumi.azure.compute.inputs.WindowsVirtualMachineOsDiskArgs;
* import com.pulumi.azure.compute.inputs.WindowsVirtualMachineSourceImageReferenceArgs;
* import com.pulumi.azure.compute.Extension;
* import com.pulumi.azure.compute.ExtensionArgs;
* import com.pulumi.azure.policy.VirtualMachineConfigurationAssignment;
* import com.pulumi.azure.policy.VirtualMachineConfigurationAssignmentArgs;
* import com.pulumi.azure.policy.inputs.VirtualMachineConfigurationAssignmentConfigurationArgs;
* 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-gca")
* .location("West Europe")
* .build());
* var exampleVirtualNetwork = new VirtualNetwork("exampleVirtualNetwork", VirtualNetworkArgs.builder()
* .name("example-vnet")
* .location(example.location())
* .resourceGroupName(example.name())
* .addressSpaces("10.0.0.0/16")
* .build());
* var exampleSubnet = new Subnet("exampleSubnet", SubnetArgs.builder()
* .name("internal")
* .resourceGroupName(example.name())
* .virtualNetworkName(exampleVirtualNetwork.name())
* .addressPrefixes("10.0.2.0/24")
* .build());
* var exampleNetworkInterface = new NetworkInterface("exampleNetworkInterface", NetworkInterfaceArgs.builder()
* .name("example-nic")
* .resourceGroupName(example.name())
* .location(example.location())
* .ipConfigurations(NetworkInterfaceIpConfigurationArgs.builder()
* .name("internal")
* .subnetId(exampleSubnet.id())
* .privateIpAddressAllocation("Dynamic")
* .build())
* .build());
* var exampleWindowsVirtualMachine = new WindowsVirtualMachine("exampleWindowsVirtualMachine", WindowsVirtualMachineArgs.builder()
* .name("examplevm")
* .resourceGroupName(example.name())
* .location(example.location())
* .size("Standard_F2")
* .adminUsername("adminuser")
* .adminPassword("P@$$w0rd1234!")
* .networkInterfaceIds(exampleNetworkInterface.id())
* .identity(WindowsVirtualMachineIdentityArgs.builder()
* .type("SystemAssigned")
* .build())
* .osDisk(WindowsVirtualMachineOsDiskArgs.builder()
* .caching("ReadWrite")
* .storageAccountType("Standard_LRS")
* .build())
* .sourceImageReference(WindowsVirtualMachineSourceImageReferenceArgs.builder()
* .publisher("MicrosoftWindowsServer")
* .offer("WindowsServer")
* .sku("2019-Datacenter")
* .version("latest")
* .build())
* .build());
* var exampleExtension = new Extension("exampleExtension", ExtensionArgs.builder()
* .name("AzurePolicyforWindows")
* .virtualMachineId(exampleWindowsVirtualMachine.id())
* .publisher("Microsoft.GuestConfiguration")
* .type("ConfigurationforWindows")
* .typeHandlerVersion("1.29")
* .autoUpgradeMinorVersion("true")
* .build());
* var exampleVirtualMachineConfigurationAssignment = new VirtualMachineConfigurationAssignment("exampleVirtualMachineConfigurationAssignment", VirtualMachineConfigurationAssignmentArgs.builder()
* .name("AzureWindowsBaseline")
* .location(exampleWindowsVirtualMachine.location())
* .virtualMachineId(exampleWindowsVirtualMachine.id())
* .configuration(VirtualMachineConfigurationAssignmentConfigurationArgs.builder()
* .assignmentType("ApplyAndMonitor")
* .version("1.*")
* .parameters(
* VirtualMachineConfigurationAssignmentConfigurationParameterArgs.builder()
* .name("Minimum Password Length;ExpectedValue")
* .value("16")
* .build(),
* VirtualMachineConfigurationAssignmentConfigurationParameterArgs.builder()
* .name("Minimum Password Age;ExpectedValue")
* .value("0")
* .build(),
* VirtualMachineConfigurationAssignmentConfigurationParameterArgs.builder()
* .name("Maximum Password Age;ExpectedValue")
* .value("30,45")
* .build(),
* VirtualMachineConfigurationAssignmentConfigurationParameterArgs.builder()
* .name("Enforce Password History;ExpectedValue")
* .value("10")
* .build(),
* VirtualMachineConfigurationAssignmentConfigurationParameterArgs.builder()
* .name("Password Must Meet Complexity Requirements;ExpectedValue")
* .value("1")
* .build())
* .build())
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: azure:core:ResourceGroup
* properties:
* name: example-gca
* location: West Europe
* exampleVirtualNetwork:
* type: azure:network:VirtualNetwork
* name: example
* properties:
* name: example-vnet
* location: ${example.location}
* resourceGroupName: ${example.name}
* addressSpaces:
* - 10.0.0.0/16
* exampleSubnet:
* type: azure:network:Subnet
* name: example
* properties:
* name: internal
* resourceGroupName: ${example.name}
* virtualNetworkName: ${exampleVirtualNetwork.name}
* addressPrefixes:
* - 10.0.2.0/24
* exampleNetworkInterface:
* type: azure:network:NetworkInterface
* name: example
* properties:
* name: example-nic
* resourceGroupName: ${example.name}
* location: ${example.location}
* ipConfigurations:
* - name: internal
* subnetId: ${exampleSubnet.id}
* privateIpAddressAllocation: Dynamic
* exampleWindowsVirtualMachine:
* type: azure:compute:WindowsVirtualMachine
* name: example
* properties:
* name: examplevm
* resourceGroupName: ${example.name}
* location: ${example.location}
* size: Standard_F2
* adminUsername: adminuser
* adminPassword: P@$$w0rd1234!
* networkInterfaceIds:
* - ${exampleNetworkInterface.id}
* identity:
* type: SystemAssigned
* osDisk:
* caching: ReadWrite
* storageAccountType: Standard_LRS
* sourceImageReference:
* publisher: MicrosoftWindowsServer
* offer: WindowsServer
* sku: 2019-Datacenter
* version: latest
* exampleExtension:
* type: azure:compute:Extension
* name: example
* properties:
* name: AzurePolicyforWindows
* virtualMachineId: ${exampleWindowsVirtualMachine.id}
* publisher: Microsoft.GuestConfiguration
* type: ConfigurationforWindows
* typeHandlerVersion: '1.29'
* autoUpgradeMinorVersion: 'true'
* exampleVirtualMachineConfigurationAssignment:
* type: azure:policy:VirtualMachineConfigurationAssignment
* name: example
* properties:
* name: AzureWindowsBaseline
* location: ${exampleWindowsVirtualMachine.location}
* virtualMachineId: ${exampleWindowsVirtualMachine.id}
* configuration:
* assignmentType: ApplyAndMonitor
* version: 1.*
* parameters:
* - name: Minimum Password Length;ExpectedValue
* value: '16'
* - name: Minimum Password Age;ExpectedValue
* value: '0'
* - name: Maximum Password Age;ExpectedValue
* value: 30,45
* - name: Enforce Password History;ExpectedValue
* value: '10'
* - name: Password Must Meet Complexity Requirements;ExpectedValue
* value: '1'
* ```
*
* ## Import
* Policy Virtual Machine Configuration Assignments can be imported using the `resource id`, e.g.
* ```sh
* $ pulumi import azure:policy/virtualMachineConfigurationAssignment:VirtualMachineConfigurationAssignment example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/group1/providers/Microsoft.Compute/virtualMachines/vm1/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/assignment1
* ```
*/
public class VirtualMachineConfigurationAssignment internal constructor(
override val javaResource: com.pulumi.azure.policy.VirtualMachineConfigurationAssignment,
) : KotlinCustomResource(javaResource, VirtualMachineConfigurationAssignmentMapper) {
/**
* A `configuration` block as defined below.
*/
public val configuration: Output
get() = javaResource.configuration().applyValue({ args0 ->
args0.let({ args0 ->
toKotlin(args0)
})
})
/**
* The Azure location where the Policy Virtual Machine Configuration Assignment should exist. Changing this forces a new resource to be created.
*/
public val location: Output
get() = javaResource.location().applyValue({ args0 -> args0 })
/**
* The name of the Guest Configuration that will be assigned in this Guest Configuration Assignment. Changing this forces a new resource to be created.
*/
public val name: Output
get() = javaResource.name().applyValue({ args0 -> args0 })
/**
* The resource ID of the Policy Virtual Machine which this Guest Configuration Assignment should apply to. Changing this forces a new resource to be created.
*/
public val virtualMachineId: Output
get() = javaResource.virtualMachineId().applyValue({ args0 -> args0 })
}
public object VirtualMachineConfigurationAssignmentMapper :
ResourceMapper {
override fun supportsMappingOfType(javaResource: Resource): Boolean =
com.pulumi.azure.policy.VirtualMachineConfigurationAssignment::class == javaResource::class
override fun map(javaResource: Resource): VirtualMachineConfigurationAssignment =
VirtualMachineConfigurationAssignment(
javaResource as
com.pulumi.azure.policy.VirtualMachineConfigurationAssignment,
)
}
/**
* @see [VirtualMachineConfigurationAssignment].
* @param name The _unique_ name of the resulting resource.
* @param block Builder for [VirtualMachineConfigurationAssignment].
*/
public suspend fun virtualMachineConfigurationAssignment(
name: String,
block: suspend VirtualMachineConfigurationAssignmentResourceBuilder.() -> Unit,
):
VirtualMachineConfigurationAssignment {
val builder = VirtualMachineConfigurationAssignmentResourceBuilder()
builder.name(name)
block(builder)
return builder.build()
}
/**
* @see [VirtualMachineConfigurationAssignment].
* @param name The _unique_ name of the resulting resource.
*/
public fun virtualMachineConfigurationAssignment(name: String):
VirtualMachineConfigurationAssignment {
val builder = VirtualMachineConfigurationAssignmentResourceBuilder()
builder.name(name)
return builder.build()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy