azure-native-v2.scvmm.MachineExtension
Explore with Pulumi AI
Describes a Machine Extension. Azure REST API version: 2022-05-21-preview.
Other available API versions: 2023-04-01-preview.
Example Usage
Create or Update a Machine Extension (PUT)
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using AzureNative = Pulumi.AzureNative;
return await Deployment.RunAsync(() => 
{
    var machineExtension = new AzureNative.ScVmm.MachineExtension("machineExtension", new()
    {
        ExtensionName = "CustomScriptExtension",
        Location = "eastus2euap",
        Publisher = "Microsoft.Compute",
        ResourceGroupName = "myResourceGroup",
        Settings = new Dictionary<string, object?>
        {
            ["commandToExecute"] = "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\"",
        },
        Type = "CustomScriptExtension",
        TypeHandlerVersion = "1.10",
        VirtualMachineName = "myMachine",
    });
});
package main
import (
	scvmm "github.com/pulumi/pulumi-azure-native-sdk/scvmm/v2"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		_, err := scvmm.NewMachineExtension(ctx, "machineExtension", &scvmm.MachineExtensionArgs{
			ExtensionName:     pulumi.String("CustomScriptExtension"),
			Location:          pulumi.String("eastus2euap"),
			Publisher:         pulumi.String("Microsoft.Compute"),
			ResourceGroupName: pulumi.String("myResourceGroup"),
			Settings: pulumi.Any(map[string]interface{}{
				"commandToExecute": "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\"",
			}),
			Type:               pulumi.String("CustomScriptExtension"),
			TypeHandlerVersion: pulumi.String("1.10"),
			VirtualMachineName: pulumi.String("myMachine"),
		})
		if err != nil {
			return err
		}
		return nil
	})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azurenative.scvmm.MachineExtension;
import com.pulumi.azurenative.scvmm.MachineExtensionArgs;
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 machineExtension = new MachineExtension("machineExtension", MachineExtensionArgs.builder()
            .extensionName("CustomScriptExtension")
            .location("eastus2euap")
            .publisher("Microsoft.Compute")
            .resourceGroupName("myResourceGroup")
            .settings(Map.of("commandToExecute", "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\""))
            .type("CustomScriptExtension")
            .typeHandlerVersion("1.10")
            .virtualMachineName("myMachine")
            .build());
    }
}
import * as pulumi from "@pulumi/pulumi";
import * as azure_native from "@pulumi/azure-native";
const machineExtension = new azure_native.scvmm.MachineExtension("machineExtension", {
    extensionName: "CustomScriptExtension",
    location: "eastus2euap",
    publisher: "Microsoft.Compute",
    resourceGroupName: "myResourceGroup",
    settings: {
        commandToExecute: "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\"",
    },
    type: "CustomScriptExtension",
    typeHandlerVersion: "1.10",
    virtualMachineName: "myMachine",
});
import pulumi
import pulumi_azure_native as azure_native
machine_extension = azure_native.scvmm.MachineExtension("machineExtension",
    extension_name="CustomScriptExtension",
    location="eastus2euap",
    publisher="Microsoft.Compute",
    resource_group_name="myResourceGroup",
    settings={
        "commandToExecute": "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\"",
    },
    type="CustomScriptExtension",
    type_handler_version="1.10",
    virtual_machine_name="myMachine")
resources:
  machineExtension:
    type: azure-native:scvmm:MachineExtension
    properties:
      extensionName: CustomScriptExtension
      location: eastus2euap
      publisher: Microsoft.Compute
      resourceGroupName: myResourceGroup
      settings:
        commandToExecute: powershell.exe -c "Get-Process | Where-Object { $_.CPU -gt 10000 }"
      type: CustomScriptExtension
      typeHandlerVersion: '1.10'
      virtualMachineName: myMachine
Create MachineExtension Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new MachineExtension(name: string, args: MachineExtensionArgs, opts?: CustomResourceOptions);@overload
def MachineExtension(resource_name: str,
                     args: MachineExtensionArgs,
                     opts: Optional[ResourceOptions] = None)
@overload
def MachineExtension(resource_name: str,
                     opts: Optional[ResourceOptions] = None,
                     resource_group_name: Optional[str] = None,
                     virtual_machine_name: Optional[str] = None,
                     publisher: Optional[str] = None,
                     force_update_tag: Optional[str] = None,
                     location: Optional[str] = None,
                     protected_settings: Optional[Any] = None,
                     auto_upgrade_minor_version: Optional[bool] = None,
                     extension_name: Optional[str] = None,
                     settings: Optional[Any] = None,
                     tags: Optional[Mapping[str, str]] = None,
                     type: Optional[str] = None,
                     type_handler_version: Optional[str] = None,
                     enable_automatic_upgrade: Optional[bool] = None)func NewMachineExtension(ctx *Context, name string, args MachineExtensionArgs, opts ...ResourceOption) (*MachineExtension, error)public MachineExtension(string name, MachineExtensionArgs args, CustomResourceOptions? opts = null)
public MachineExtension(String name, MachineExtensionArgs args)
public MachineExtension(String name, MachineExtensionArgs args, CustomResourceOptions options)
type: azure-native:scvmm:MachineExtension
properties: # The arguments to resource properties.
options: # Bag of options to control resource's behavior.
Parameters
- name string
- The unique name of the resource.
- args MachineExtensionArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- resource_name str
- The unique name of the resource.
- args MachineExtensionArgs
- The arguments to resource properties.
- opts ResourceOptions
- Bag of options to control resource's behavior.
- ctx Context
- Context object for the current deployment.
- name string
- The unique name of the resource.
- args MachineExtensionArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args MachineExtensionArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args MachineExtensionArgs
- The arguments to resource properties.
- options CustomResourceOptions
- Bag of options to control resource's behavior.
Constructor example
The following reference example uses placeholder values for all input properties.
var examplemachineExtensionResourceResourceFromScvmm = new AzureNative.Scvmm.MachineExtension("examplemachineExtensionResourceResourceFromScvmm", new()
{
    ResourceGroupName = "string",
    VirtualMachineName = "string",
    Publisher = "string",
    ForceUpdateTag = "string",
    Location = "string",
    ProtectedSettings = "any",
    AutoUpgradeMinorVersion = false,
    ExtensionName = "string",
    Settings = "any",
    Tags = 
    {
        { "string", "string" },
    },
    Type = "string",
    TypeHandlerVersion = "string",
    EnableAutomaticUpgrade = false,
});
example, err := scvmm.NewMachineExtension(ctx, "examplemachineExtensionResourceResourceFromScvmm", &scvmm.MachineExtensionArgs{
	ResourceGroupName:       "string",
	VirtualMachineName:      "string",
	Publisher:               "string",
	ForceUpdateTag:          "string",
	Location:                "string",
	ProtectedSettings:       "any",
	AutoUpgradeMinorVersion: false,
	ExtensionName:           "string",
	Settings:                "any",
	Tags: map[string]interface{}{
		"string": "string",
	},
	Type:                   "string",
	TypeHandlerVersion:     "string",
	EnableAutomaticUpgrade: false,
})
var examplemachineExtensionResourceResourceFromScvmm = new com.pulumi.azurenative.scvmm.MachineExtension("examplemachineExtensionResourceResourceFromScvmm", com.pulumi.azurenative.scvmm.MachineExtensionArgs.builder()
    .resourceGroupName("string")
    .virtualMachineName("string")
    .publisher("string")
    .forceUpdateTag("string")
    .location("string")
    .protectedSettings("any")
    .autoUpgradeMinorVersion(false)
    .extensionName("string")
    .settings("any")
    .tags(Map.of("string", "string"))
    .type("string")
    .typeHandlerVersion("string")
    .enableAutomaticUpgrade(false)
    .build());
examplemachine_extension_resource_resource_from_scvmm = azure_native.scvmm.MachineExtension("examplemachineExtensionResourceResourceFromScvmm",
    resource_group_name=string,
    virtual_machine_name=string,
    publisher=string,
    force_update_tag=string,
    location=string,
    protected_settings=any,
    auto_upgrade_minor_version=False,
    extension_name=string,
    settings=any,
    tags={
        string: string,
    },
    type=string,
    type_handler_version=string,
    enable_automatic_upgrade=False)
const examplemachineExtensionResourceResourceFromScvmm = new azure_native.scvmm.MachineExtension("examplemachineExtensionResourceResourceFromScvmm", {
    resourceGroupName: "string",
    virtualMachineName: "string",
    publisher: "string",
    forceUpdateTag: "string",
    location: "string",
    protectedSettings: "any",
    autoUpgradeMinorVersion: false,
    extensionName: "string",
    settings: "any",
    tags: {
        string: "string",
    },
    type: "string",
    typeHandlerVersion: "string",
    enableAutomaticUpgrade: false,
});
type: azure-native:scvmm:MachineExtension
properties:
    autoUpgradeMinorVersion: false
    enableAutomaticUpgrade: false
    extensionName: string
    forceUpdateTag: string
    location: string
    protectedSettings: any
    publisher: string
    resourceGroupName: string
    settings: any
    tags:
        string: string
    type: string
    typeHandlerVersion: string
    virtualMachineName: string
MachineExtension Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
In Python, inputs that are objects can be passed either as argument classes or as dictionary literals.
The MachineExtension resource accepts the following input properties:
- ResourceGroup stringName 
- The name of the resource group.
- VirtualMachine stringName 
- The name of the machine where the extension should be created or updated.
- AutoUpgrade boolMinor Version 
- Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
- EnableAutomatic boolUpgrade 
- Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
- ExtensionName string
- The name of the machine extension.
- ForceUpdate stringTag 
- How the extension handler should be forced to update even if the extension configuration has not changed.
- Location string
- The geo-location where the resource lives
- ProtectedSettings object
- The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
- Publisher string
- The name of the extension handler publisher.
- Settings object
- Json formatted public settings for the extension.
- Dictionary<string, string>
- Resource tags.
- Type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- TypeHandler stringVersion 
- Specifies the version of the script handler.
- ResourceGroup stringName 
- The name of the resource group.
- VirtualMachine stringName 
- The name of the machine where the extension should be created or updated.
- AutoUpgrade boolMinor Version 
- Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
- EnableAutomatic boolUpgrade 
- Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
- ExtensionName string
- The name of the machine extension.
- ForceUpdate stringTag 
- How the extension handler should be forced to update even if the extension configuration has not changed.
- Location string
- The geo-location where the resource lives
- ProtectedSettings interface{}
- The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
- Publisher string
- The name of the extension handler publisher.
- Settings interface{}
- Json formatted public settings for the extension.
- map[string]string
- Resource tags.
- Type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- TypeHandler stringVersion 
- Specifies the version of the script handler.
- resourceGroup StringName 
- The name of the resource group.
- virtualMachine StringName 
- The name of the machine where the extension should be created or updated.
- autoUpgrade BooleanMinor Version 
- Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
- enableAutomatic BooleanUpgrade 
- Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
- extensionName String
- The name of the machine extension.
- forceUpdate StringTag 
- How the extension handler should be forced to update even if the extension configuration has not changed.
- location String
- The geo-location where the resource lives
- protectedSettings Object
- The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
- publisher String
- The name of the extension handler publisher.
- settings Object
- Json formatted public settings for the extension.
- Map<String,String>
- Resource tags.
- type String
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler StringVersion 
- Specifies the version of the script handler.
- resourceGroup stringName 
- The name of the resource group.
- virtualMachine stringName 
- The name of the machine where the extension should be created or updated.
- autoUpgrade booleanMinor Version 
- Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
- enableAutomatic booleanUpgrade 
- Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
- extensionName string
- The name of the machine extension.
- forceUpdate stringTag 
- How the extension handler should be forced to update even if the extension configuration has not changed.
- location string
- The geo-location where the resource lives
- protectedSettings any
- The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
- publisher string
- The name of the extension handler publisher.
- settings any
- Json formatted public settings for the extension.
- {[key: string]: string}
- Resource tags.
- type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler stringVersion 
- Specifies the version of the script handler.
- resource_group_ strname 
- The name of the resource group.
- virtual_machine_ strname 
- The name of the machine where the extension should be created or updated.
- auto_upgrade_ boolminor_ version 
- Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
- enable_automatic_ boolupgrade 
- Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
- extension_name str
- The name of the machine extension.
- force_update_ strtag 
- How the extension handler should be forced to update even if the extension configuration has not changed.
- location str
- The geo-location where the resource lives
- protected_settings Any
- The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
- publisher str
- The name of the extension handler publisher.
- settings Any
- Json formatted public settings for the extension.
- Mapping[str, str]
- Resource tags.
- type str
- Specifies the type of the extension; an example is "CustomScriptExtension".
- type_handler_ strversion 
- Specifies the version of the script handler.
- resourceGroup StringName 
- The name of the resource group.
- virtualMachine StringName 
- The name of the machine where the extension should be created or updated.
- autoUpgrade BooleanMinor Version 
- Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true.
- enableAutomatic BooleanUpgrade 
- Indicates whether the extension should be automatically upgraded by the platform if there is a newer version available.
- extensionName String
- The name of the machine extension.
- forceUpdate StringTag 
- How the extension handler should be forced to update even if the extension configuration has not changed.
- location String
- The geo-location where the resource lives
- protectedSettings Any
- The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all.
- publisher String
- The name of the extension handler publisher.
- settings Any
- Json formatted public settings for the extension.
- Map<String>
- Resource tags.
- type String
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler StringVersion 
- Specifies the version of the script handler.
Outputs
All input properties are implicitly available as output properties. Additionally, the MachineExtension resource produces the following output properties:
- Id string
- The provider-assigned unique ID for this managed resource.
- Name string
- The name of the resource
- ProvisioningState string
- The provisioning state, which only appears in the response.
- SystemData Pulumi.Azure Native. Sc Vmm. Outputs. System Data Response 
- Azure Resource Manager metadata containing createdBy and modifiedBy information.
- InstanceView Pulumi.Azure Native. Sc Vmm. Outputs. Machine Extension Properties Response Instance View 
- The machine extension instance view.
- Id string
- The provider-assigned unique ID for this managed resource.
- Name string
- The name of the resource
- ProvisioningState string
- The provisioning state, which only appears in the response.
- SystemData SystemData Response 
- Azure Resource Manager metadata containing createdBy and modifiedBy information.
- InstanceView MachineExtension Properties Response Instance View 
- The machine extension instance view.
- id String
- The provider-assigned unique ID for this managed resource.
- name String
- The name of the resource
- provisioningState String
- The provisioning state, which only appears in the response.
- systemData SystemData Response 
- Azure Resource Manager metadata containing createdBy and modifiedBy information.
- instanceView MachineExtension Properties Response Instance View 
- The machine extension instance view.
- id string
- The provider-assigned unique ID for this managed resource.
- name string
- The name of the resource
- provisioningState string
- The provisioning state, which only appears in the response.
- systemData SystemData Response 
- Azure Resource Manager metadata containing createdBy and modifiedBy information.
- instanceView MachineExtension Properties Response Instance View 
- The machine extension instance view.
- id str
- The provider-assigned unique ID for this managed resource.
- name str
- The name of the resource
- provisioning_state str
- The provisioning state, which only appears in the response.
- system_data SystemData Response 
- Azure Resource Manager metadata containing createdBy and modifiedBy information.
- instance_view MachineExtension Properties Response Instance View 
- The machine extension instance view.
- id String
- The provider-assigned unique ID for this managed resource.
- name String
- The name of the resource
- provisioningState String
- The provisioning state, which only appears in the response.
- systemData Property Map
- Azure Resource Manager metadata containing createdBy and modifiedBy information.
- instanceView Property Map
- The machine extension instance view.
Supporting Types
MachineExtensionInstanceViewResponseStatus, MachineExtensionInstanceViewResponseStatusArgs            
- Code string
- The status code.
- DisplayStatus string
- The short localizable label for the status.
- Level string
- The level code.
- Message string
- The detailed status message, including for alerts and error messages.
- Time string
- The time of the status.
- Code string
- The status code.
- DisplayStatus string
- The short localizable label for the status.
- Level string
- The level code.
- Message string
- The detailed status message, including for alerts and error messages.
- Time string
- The time of the status.
- code String
- The status code.
- displayStatus String
- The short localizable label for the status.
- level String
- The level code.
- message String
- The detailed status message, including for alerts and error messages.
- time String
- The time of the status.
- code string
- The status code.
- displayStatus string
- The short localizable label for the status.
- level string
- The level code.
- message string
- The detailed status message, including for alerts and error messages.
- time string
- The time of the status.
- code str
- The status code.
- display_status str
- The short localizable label for the status.
- level str
- The level code.
- message str
- The detailed status message, including for alerts and error messages.
- time str
- The time of the status.
- code String
- The status code.
- displayStatus String
- The short localizable label for the status.
- level String
- The level code.
- message String
- The detailed status message, including for alerts and error messages.
- time String
- The time of the status.
MachineExtensionPropertiesResponseInstanceView, MachineExtensionPropertiesResponseInstanceViewArgs            
- Name string
- The machine extension name.
- Type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- TypeHandler stringVersion 
- Specifies the version of the script handler.
- Status
Pulumi.Azure Native. Sc Vmm. Inputs. Machine Extension Instance View Response Status 
- Instance view status.
- Name string
- The machine extension name.
- Type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- TypeHandler stringVersion 
- Specifies the version of the script handler.
- Status
MachineExtension Instance View Response Status 
- Instance view status.
- name String
- The machine extension name.
- type String
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler StringVersion 
- Specifies the version of the script handler.
- status
MachineExtension Instance View Response Status 
- Instance view status.
- name string
- The machine extension name.
- type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler stringVersion 
- Specifies the version of the script handler.
- status
MachineExtension Instance View Response Status 
- Instance view status.
- name str
- The machine extension name.
- type str
- Specifies the type of the extension; an example is "CustomScriptExtension".
- type_handler_ strversion 
- Specifies the version of the script handler.
- status
MachineExtension Instance View Response Status 
- Instance view status.
- name String
- The machine extension name.
- type String
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler StringVersion 
- Specifies the version of the script handler.
- status Property Map
- Instance view status.
SystemDataResponse, SystemDataResponseArgs      
- CreatedAt string
- The timestamp of resource creation (UTC).
- CreatedBy string
- The identity that created the resource.
- CreatedBy stringType 
- The type of identity that created the resource.
- LastModified stringAt 
- The timestamp of resource last modification (UTC)
- LastModified stringBy 
- The identity that last modified the resource.
- LastModified stringBy Type 
- The type of identity that last modified the resource.
- CreatedAt string
- The timestamp of resource creation (UTC).
- CreatedBy string
- The identity that created the resource.
- CreatedBy stringType 
- The type of identity that created the resource.
- LastModified stringAt 
- The timestamp of resource last modification (UTC)
- LastModified stringBy 
- The identity that last modified the resource.
- LastModified stringBy Type 
- The type of identity that last modified the resource.
- createdAt String
- The timestamp of resource creation (UTC).
- createdBy String
- The identity that created the resource.
- createdBy StringType 
- The type of identity that created the resource.
- lastModified StringAt 
- The timestamp of resource last modification (UTC)
- lastModified StringBy 
- The identity that last modified the resource.
- lastModified StringBy Type 
- The type of identity that last modified the resource.
- createdAt string
- The timestamp of resource creation (UTC).
- createdBy string
- The identity that created the resource.
- createdBy stringType 
- The type of identity that created the resource.
- lastModified stringAt 
- The timestamp of resource last modification (UTC)
- lastModified stringBy 
- The identity that last modified the resource.
- lastModified stringBy Type 
- The type of identity that last modified the resource.
- created_at str
- The timestamp of resource creation (UTC).
- created_by str
- The identity that created the resource.
- created_by_ strtype 
- The type of identity that created the resource.
- last_modified_ strat 
- The timestamp of resource last modification (UTC)
- last_modified_ strby 
- The identity that last modified the resource.
- last_modified_ strby_ type 
- The type of identity that last modified the resource.
- createdAt String
- The timestamp of resource creation (UTC).
- createdBy String
- The identity that created the resource.
- createdBy StringType 
- The type of identity that created the resource.
- lastModified StringAt 
- The timestamp of resource last modification (UTC)
- lastModified StringBy 
- The identity that last modified the resource.
- lastModified StringBy Type 
- The type of identity that last modified the resource.
Import
An existing resource can be imported using its type token, name, and identifier, e.g.
$ pulumi import azure-native:scvmm:MachineExtension CustomScriptExtension /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ScVmm/virtualMachines/{virtualMachineName}/extensions/{extensionName} 
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- azure-native-v2 pulumi/pulumi-azure-native
- License
- Apache-2.0