azure-native.azurestackhci.MachineExtension
Explore with Pulumi AI
Describes a Machine Extension.
Uses Azure REST API version 2022-12-15-preview. In version 2.x of the Azure Native provider, it used API version 2022-12-15-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.AzureStackHCI.MachineExtension("machineExtension", new()
    {
        ExtensionName = "CustomScriptExtension",
        Location = "eastus2euap",
        Name = "myMachine",
        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",
    });
});
package main
import (
	azurestackhci "github.com/pulumi/pulumi-azure-native-sdk/azurestackhci/v3"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		_, err := azurestackhci.NewMachineExtension(ctx, "machineExtension", &azurestackhci.MachineExtensionArgs{
			ExtensionName:     pulumi.String("CustomScriptExtension"),
			Location:          pulumi.String("eastus2euap"),
			Name:              pulumi.String("myMachine"),
			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"),
		})
		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.azurestackhci.MachineExtension;
import com.pulumi.azurenative.azurestackhci.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")
            .name("myMachine")
            .publisher("Microsoft.Compute")
            .resourceGroupName("myResourceGroup")
            .settings(Map.of("commandToExecute", "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\""))
            .type("CustomScriptExtension")
            .typeHandlerVersion("1.10")
            .build());
    }
}
import * as pulumi from "@pulumi/pulumi";
import * as azure_native from "@pulumi/azure-native";
const machineExtension = new azure_native.azurestackhci.MachineExtension("machineExtension", {
    extensionName: "CustomScriptExtension",
    location: "eastus2euap",
    name: "myMachine",
    publisher: "Microsoft.Compute",
    resourceGroupName: "myResourceGroup",
    settings: {
        commandToExecute: "powershell.exe -c \"Get-Process | Where-Object { $_.CPU -gt 10000 }\"",
    },
    type: "CustomScriptExtension",
    typeHandlerVersion: "1.10",
});
import pulumi
import pulumi_azure_native as azure_native
machine_extension = azure_native.azurestackhci.MachineExtension("machineExtension",
    extension_name="CustomScriptExtension",
    location="eastus2euap",
    name="myMachine",
    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")
resources:
  machineExtension:
    type: azure-native:azurestackhci:MachineExtension
    properties:
      extensionName: CustomScriptExtension
      location: eastus2euap
      name: myMachine
      publisher: Microsoft.Compute
      resourceGroupName: myResourceGroup
      settings:
        commandToExecute: powershell.exe -c "Get-Process | Where-Object { $_.CPU -gt 10000 }"
      type: CustomScriptExtension
      typeHandlerVersion: '1.10'
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,
                     name: Optional[str] = None,
                     resource_group_name: Optional[str] = None,
                     auto_upgrade_minor_version: Optional[bool] = None,
                     extension_name: Optional[str] = None,
                     force_update_tag: Optional[str] = None,
                     location: Optional[str] = None,
                     protected_settings: Optional[Any] = None,
                     publisher: Optional[str] = None,
                     settings: Optional[Any] = None,
                     tags: Optional[Mapping[str, str]] = None,
                     type: Optional[str] = None,
                     type_handler_version: Optional[str] = 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:azurestackhci: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 machineExtensionResource = new AzureNative.AzureStackHCI.MachineExtension("machineExtensionResource", new()
{
    Name = "string",
    ResourceGroupName = "string",
    AutoUpgradeMinorVersion = false,
    ExtensionName = "string",
    ForceUpdateTag = "string",
    Location = "string",
    ProtectedSettings = "any",
    Publisher = "string",
    Settings = "any",
    Tags = 
    {
        { "string", "string" },
    },
    Type = "string",
    TypeHandlerVersion = "string",
});
example, err := azurestackhci.NewMachineExtension(ctx, "machineExtensionResource", &azurestackhci.MachineExtensionArgs{
	Name:                    pulumi.String("string"),
	ResourceGroupName:       pulumi.String("string"),
	AutoUpgradeMinorVersion: pulumi.Bool(false),
	ExtensionName:           pulumi.String("string"),
	ForceUpdateTag:          pulumi.String("string"),
	Location:                pulumi.String("string"),
	ProtectedSettings:       pulumi.Any("any"),
	Publisher:               pulumi.String("string"),
	Settings:                pulumi.Any("any"),
	Tags: pulumi.StringMap{
		"string": pulumi.String("string"),
	},
	Type:               pulumi.String("string"),
	TypeHandlerVersion: pulumi.String("string"),
})
var machineExtensionResource = new com.pulumi.azurenative.azurestackhci.MachineExtension("machineExtensionResource", com.pulumi.azurenative.azurestackhci.MachineExtensionArgs.builder()
    .name("string")
    .resourceGroupName("string")
    .autoUpgradeMinorVersion(false)
    .extensionName("string")
    .forceUpdateTag("string")
    .location("string")
    .protectedSettings("any")
    .publisher("string")
    .settings("any")
    .tags(Map.of("string", "string"))
    .type("string")
    .typeHandlerVersion("string")
    .build());
machine_extension_resource = azure_native.azurestackhci.MachineExtension("machineExtensionResource",
    name="string",
    resource_group_name="string",
    auto_upgrade_minor_version=False,
    extension_name="string",
    force_update_tag="string",
    location="string",
    protected_settings="any",
    publisher="string",
    settings="any",
    tags={
        "string": "string",
    },
    type="string",
    type_handler_version="string")
const machineExtensionResource = new azure_native.azurestackhci.MachineExtension("machineExtensionResource", {
    name: "string",
    resourceGroupName: "string",
    autoUpgradeMinorVersion: false,
    extensionName: "string",
    forceUpdateTag: "string",
    location: "string",
    protectedSettings: "any",
    publisher: "string",
    settings: "any",
    tags: {
        string: "string",
    },
    type: "string",
    typeHandlerVersion: "string",
});
type: azure-native:azurestackhci:MachineExtension
properties:
    autoUpgradeMinorVersion: false
    extensionName: string
    forceUpdateTag: string
    location: string
    name: string
    protectedSettings: any
    publisher: string
    resourceGroupName: string
    settings: any
    tags:
        string: string
    type: string
    typeHandlerVersion: 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:
- Name string
- The name of the machine where the extension should be created or updated.
- ResourceGroup stringName 
- The name of the resource group. The name is case insensitive.
- 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.
- 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 location.
- 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>
- The Resource tags.
- Type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- TypeHandler stringVersion 
- Specifies the version of the script handler.
- Name string
- The name of the machine where the extension should be created or updated.
- ResourceGroup stringName 
- The name of the resource group. The name is case insensitive.
- 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.
- 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 location.
- 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
- The Resource tags.
- Type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- TypeHandler stringVersion 
- Specifies the version of the script handler.
- name String
- The name of the machine where the extension should be created or updated.
- resourceGroup StringName 
- The name of the resource group. The name is case insensitive.
- 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.
- 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 location.
- 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>
- The Resource tags.
- type String
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler StringVersion 
- Specifies the version of the script handler.
- name string
- The name of the machine where the extension should be created or updated.
- resourceGroup stringName 
- The name of the resource group. The name is case insensitive.
- 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.
- 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 location.
- 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}
- The Resource tags.
- type string
- Specifies the type of the extension; an example is "CustomScriptExtension".
- typeHandler stringVersion 
- Specifies the version of the script handler.
- name str
- The name of the machine where the extension should be created or updated.
- resource_group_ strname 
- The name of the resource group. The name is case insensitive.
- 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.
- 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 location.
- 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]
- The Resource tags.
- type str
- Specifies the type of the extension; an example is "CustomScriptExtension".
- type_handler_ strversion 
- Specifies the version of the script handler.
- name String
- The name of the machine where the extension should be created or updated.
- resourceGroup StringName 
- The name of the resource group. The name is case insensitive.
- 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.
- 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 location.
- 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>
- The 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:
- AzureApi stringVersion 
- The Azure API version of the resource.
- Id string
- The provider-assigned unique ID for this managed resource.
- ProvisioningState string
- The provisioning state, which only appears in the response.
- SystemData Pulumi.Azure Native. Azure Stack HCI. Outputs. System Data Response 
- The system data.
- InstanceView Pulumi.Azure Native. Azure Stack HCI. Outputs. Machine Extension Properties Response Instance View 
- The machine extension instance view.
- AzureApi stringVersion 
- The Azure API version of the resource.
- Id string
- The provider-assigned unique ID for this managed resource.
- ProvisioningState string
- The provisioning state, which only appears in the response.
- SystemData SystemData Response 
- The system data.
- InstanceView MachineExtension Properties Response Instance View 
- The machine extension instance view.
- azureApi StringVersion 
- The Azure API version of the resource.
- id String
- The provider-assigned unique ID for this managed resource.
- provisioningState String
- The provisioning state, which only appears in the response.
- systemData SystemData Response 
- The system data.
- instanceView MachineExtension Properties Response Instance View 
- The machine extension instance view.
- azureApi stringVersion 
- The Azure API version of the resource.
- id string
- The provider-assigned unique ID for this managed resource.
- provisioningState string
- The provisioning state, which only appears in the response.
- systemData SystemData Response 
- The system data.
- instanceView MachineExtension Properties Response Instance View 
- The machine extension instance view.
- azure_api_ strversion 
- The Azure API version of the resource.
- id str
- The provider-assigned unique ID for this managed resource.
- provisioning_state str
- The provisioning state, which only appears in the response.
- system_data SystemData Response 
- The system data.
- instance_view MachineExtension Properties Response Instance View 
- The machine extension instance view.
- azureApi StringVersion 
- The Azure API version of the resource.
- id String
- The provider-assigned unique ID for this managed resource.
- provisioningState String
- The provisioning state, which only appears in the response.
- systemData Property Map
- The system data.
- 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. Azure Stack HCI. 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:azurestackhci:MachineExtension CustomScriptExtension /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.AzureStackHCI/virtualMachines/{name}/extensions/{extensionName} 
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- Azure Native pulumi/pulumi-azure-native
- License
- Apache-2.0