We recommend using Azure Native.
azure.bot.ChannelFacebook
Explore with Pulumi AI
Manages a Facebook integration for a Bot Channel
Note A bot can only have a single Facebook Channel associated with it.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const current = azure.core.getClientConfig({});
const example = new azure.core.ResourceGroup("example", {
name: "example-resources",
location: "West Europe",
});
const exampleChannelsRegistration = new azure.bot.ChannelsRegistration("example", {
name: "example-bcr",
location: "global",
resourceGroupName: example.name,
sku: "F0",
microsoftAppId: current.then(current => current.clientId),
});
const exampleChannelFacebook = new azure.bot.ChannelFacebook("example", {
botName: exampleChannelsRegistration.name,
location: exampleChannelsRegistration.location,
resourceGroupName: example.name,
facebookApplicationId: "563490254873576",
facebookApplicationSecret: "8976d2536445ad5b976dee8437b9beb0",
pages: [{
id: "876248795081953",
accessToken: "CGGCec3UAFPMBAKwK3Ft8SEpO8ZCuvpNBI5DClaJCDfqJj2BgEHCKxcY0FDarmUQap6XxpZC9GWCW4nZCzjcKosAZAP7SO44X8Q8gAntbDIXgYUBGp9xtS8wUkwgKPobUePcOOVFkvClxvYZByuiQxoTiK9fQ9jZCPEorbmZCsKDZAx4VLnrNwCTZAPUwXxO61gfq4ZD",
}],
});
import pulumi
import pulumi_azure as azure
current = azure.core.get_client_config()
example = azure.core.ResourceGroup("example",
name="example-resources",
location="West Europe")
example_channels_registration = azure.bot.ChannelsRegistration("example",
name="example-bcr",
location="global",
resource_group_name=example.name,
sku="F0",
microsoft_app_id=current.client_id)
example_channel_facebook = azure.bot.ChannelFacebook("example",
bot_name=example_channels_registration.name,
location=example_channels_registration.location,
resource_group_name=example.name,
facebook_application_id="563490254873576",
facebook_application_secret="8976d2536445ad5b976dee8437b9beb0",
pages=[azure.bot.ChannelFacebookPageArgs(
id="876248795081953",
access_token="CGGCec3UAFPMBAKwK3Ft8SEpO8ZCuvpNBI5DClaJCDfqJj2BgEHCKxcY0FDarmUQap6XxpZC9GWCW4nZCzjcKosAZAP7SO44X8Q8gAntbDIXgYUBGp9xtS8wUkwgKPobUePcOOVFkvClxvYZByuiQxoTiK9fQ9jZCPEorbmZCsKDZAx4VLnrNwCTZAPUwXxO61gfq4ZD",
)])
package main
import (
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/bot"
"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
"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
}
example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
Name: pulumi.String("example-resources"),
Location: pulumi.String("West Europe"),
})
if err != nil {
return err
}
exampleChannelsRegistration, err := bot.NewChannelsRegistration(ctx, "example", &bot.ChannelsRegistrationArgs{
Name: pulumi.String("example-bcr"),
Location: pulumi.String("global"),
ResourceGroupName: example.Name,
Sku: pulumi.String("F0"),
MicrosoftAppId: pulumi.String(current.ClientId),
})
if err != nil {
return err
}
_, err = bot.NewChannelFacebook(ctx, "example", &bot.ChannelFacebookArgs{
BotName: exampleChannelsRegistration.Name,
Location: exampleChannelsRegistration.Location,
ResourceGroupName: example.Name,
FacebookApplicationId: pulumi.String("563490254873576"),
FacebookApplicationSecret: pulumi.String("8976d2536445ad5b976dee8437b9beb0"),
Pages: bot.ChannelFacebookPageArray{
&bot.ChannelFacebookPageArgs{
Id: pulumi.String("876248795081953"),
AccessToken: pulumi.String("CGGCec3UAFPMBAKwK3Ft8SEpO8ZCuvpNBI5DClaJCDfqJj2BgEHCKxcY0FDarmUQap6XxpZC9GWCW4nZCzjcKosAZAP7SO44X8Q8gAntbDIXgYUBGp9xtS8wUkwgKPobUePcOOVFkvClxvYZByuiQxoTiK9fQ9jZCPEorbmZCsKDZAx4VLnrNwCTZAPUwXxO61gfq4ZD"),
},
},
})
if err != nil {
return err
}
return nil
})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() =>
{
var current = Azure.Core.GetClientConfig.Invoke();
var example = new Azure.Core.ResourceGroup("example", new()
{
Name = "example-resources",
Location = "West Europe",
});
var exampleChannelsRegistration = new Azure.Bot.ChannelsRegistration("example", new()
{
Name = "example-bcr",
Location = "global",
ResourceGroupName = example.Name,
Sku = "F0",
MicrosoftAppId = current.Apply(getClientConfigResult => getClientConfigResult.ClientId),
});
var exampleChannelFacebook = new Azure.Bot.ChannelFacebook("example", new()
{
BotName = exampleChannelsRegistration.Name,
Location = exampleChannelsRegistration.Location,
ResourceGroupName = example.Name,
FacebookApplicationId = "563490254873576",
FacebookApplicationSecret = "8976d2536445ad5b976dee8437b9beb0",
Pages = new[]
{
new Azure.Bot.Inputs.ChannelFacebookPageArgs
{
Id = "876248795081953",
AccessToken = "CGGCec3UAFPMBAKwK3Ft8SEpO8ZCuvpNBI5DClaJCDfqJj2BgEHCKxcY0FDarmUQap6XxpZC9GWCW4nZCzjcKosAZAP7SO44X8Q8gAntbDIXgYUBGp9xtS8wUkwgKPobUePcOOVFkvClxvYZByuiQxoTiK9fQ9jZCPEorbmZCsKDZAx4VLnrNwCTZAPUwXxO61gfq4ZD",
},
},
});
});
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.core.ResourceGroup;
import com.pulumi.azure.core.ResourceGroupArgs;
import com.pulumi.azure.bot.ChannelsRegistration;
import com.pulumi.azure.bot.ChannelsRegistrationArgs;
import com.pulumi.azure.bot.ChannelFacebook;
import com.pulumi.azure.bot.ChannelFacebookArgs;
import com.pulumi.azure.bot.inputs.ChannelFacebookPageArgs;
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();
var example = new ResourceGroup("example", ResourceGroupArgs.builder()
.name("example-resources")
.location("West Europe")
.build());
var exampleChannelsRegistration = new ChannelsRegistration("exampleChannelsRegistration", ChannelsRegistrationArgs.builder()
.name("example-bcr")
.location("global")
.resourceGroupName(example.name())
.sku("F0")
.microsoftAppId(current.applyValue(getClientConfigResult -> getClientConfigResult.clientId()))
.build());
var exampleChannelFacebook = new ChannelFacebook("exampleChannelFacebook", ChannelFacebookArgs.builder()
.botName(exampleChannelsRegistration.name())
.location(exampleChannelsRegistration.location())
.resourceGroupName(example.name())
.facebookApplicationId("563490254873576")
.facebookApplicationSecret("8976d2536445ad5b976dee8437b9beb0")
.pages(ChannelFacebookPageArgs.builder()
.id("876248795081953")
.accessToken("CGGCec3UAFPMBAKwK3Ft8SEpO8ZCuvpNBI5DClaJCDfqJj2BgEHCKxcY0FDarmUQap6XxpZC9GWCW4nZCzjcKosAZAP7SO44X8Q8gAntbDIXgYUBGp9xtS8wUkwgKPobUePcOOVFkvClxvYZByuiQxoTiK9fQ9jZCPEorbmZCsKDZAx4VLnrNwCTZAPUwXxO61gfq4ZD")
.build())
.build());
}
}
resources:
example:
type: azure:core:ResourceGroup
properties:
name: example-resources
location: West Europe
exampleChannelsRegistration:
type: azure:bot:ChannelsRegistration
name: example
properties:
name: example-bcr
location: global
resourceGroupName: ${example.name}
sku: F0
microsoftAppId: ${current.clientId}
exampleChannelFacebook:
type: azure:bot:ChannelFacebook
name: example
properties:
botName: ${exampleChannelsRegistration.name}
location: ${exampleChannelsRegistration.location}
resourceGroupName: ${example.name}
facebookApplicationId: '563490254873576'
facebookApplicationSecret: 8976d2536445ad5b976dee8437b9beb0
pages:
- id: '876248795081953'
accessToken: CGGCec3UAFPMBAKwK3Ft8SEpO8ZCuvpNBI5DClaJCDfqJj2BgEHCKxcY0FDarmUQap6XxpZC9GWCW4nZCzjcKosAZAP7SO44X8Q8gAntbDIXgYUBGp9xtS8wUkwgKPobUePcOOVFkvClxvYZByuiQxoTiK9fQ9jZCPEorbmZCsKDZAx4VLnrNwCTZAPUwXxO61gfq4ZD
variables:
current:
fn::invoke:
Function: azure:core:getClientConfig
Arguments: {}
Create ChannelFacebook Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new ChannelFacebook(name: string, args: ChannelFacebookArgs, opts?: CustomResourceOptions);
@overload
def ChannelFacebook(resource_name: str,
args: ChannelFacebookArgs,
opts: Optional[ResourceOptions] = None)
@overload
def ChannelFacebook(resource_name: str,
opts: Optional[ResourceOptions] = None,
bot_name: Optional[str] = None,
facebook_application_id: Optional[str] = None,
facebook_application_secret: Optional[str] = None,
pages: Optional[Sequence[ChannelFacebookPageArgs]] = None,
resource_group_name: Optional[str] = None,
location: Optional[str] = None)
func NewChannelFacebook(ctx *Context, name string, args ChannelFacebookArgs, opts ...ResourceOption) (*ChannelFacebook, error)
public ChannelFacebook(string name, ChannelFacebookArgs args, CustomResourceOptions? opts = null)
public ChannelFacebook(String name, ChannelFacebookArgs args)
public ChannelFacebook(String name, ChannelFacebookArgs args, CustomResourceOptions options)
type: azure:bot:ChannelFacebook
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 ChannelFacebookArgs
- 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 ChannelFacebookArgs
- 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 ChannelFacebookArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args ChannelFacebookArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args ChannelFacebookArgs
- 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 channelFacebookResource = new Azure.Bot.ChannelFacebook("channelFacebookResource", new()
{
BotName = "string",
FacebookApplicationId = "string",
FacebookApplicationSecret = "string",
Pages = new[]
{
new Azure.Bot.Inputs.ChannelFacebookPageArgs
{
AccessToken = "string",
Id = "string",
},
},
ResourceGroupName = "string",
Location = "string",
});
example, err := bot.NewChannelFacebook(ctx, "channelFacebookResource", &bot.ChannelFacebookArgs{
BotName: pulumi.String("string"),
FacebookApplicationId: pulumi.String("string"),
FacebookApplicationSecret: pulumi.String("string"),
Pages: bot.ChannelFacebookPageArray{
&bot.ChannelFacebookPageArgs{
AccessToken: pulumi.String("string"),
Id: pulumi.String("string"),
},
},
ResourceGroupName: pulumi.String("string"),
Location: pulumi.String("string"),
})
var channelFacebookResource = new ChannelFacebook("channelFacebookResource", ChannelFacebookArgs.builder()
.botName("string")
.facebookApplicationId("string")
.facebookApplicationSecret("string")
.pages(ChannelFacebookPageArgs.builder()
.accessToken("string")
.id("string")
.build())
.resourceGroupName("string")
.location("string")
.build());
channel_facebook_resource = azure.bot.ChannelFacebook("channelFacebookResource",
bot_name="string",
facebook_application_id="string",
facebook_application_secret="string",
pages=[azure.bot.ChannelFacebookPageArgs(
access_token="string",
id="string",
)],
resource_group_name="string",
location="string")
const channelFacebookResource = new azure.bot.ChannelFacebook("channelFacebookResource", {
botName: "string",
facebookApplicationId: "string",
facebookApplicationSecret: "string",
pages: [{
accessToken: "string",
id: "string",
}],
resourceGroupName: "string",
location: "string",
});
type: azure:bot:ChannelFacebook
properties:
botName: string
facebookApplicationId: string
facebookApplicationSecret: string
location: string
pages:
- accessToken: string
id: string
resourceGroupName: string
ChannelFacebook Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
The ChannelFacebook resource accepts the following input properties:
- Bot
Name string - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- Facebook
Application stringId - The Facebook Application ID for the Facebook Channel.
- Facebook
Application stringSecret - The Facebook Application Secret for the Facebook Channel.
- Pages
List<Channel
Facebook Page> - One or more
page
blocks as defined below. - Resource
Group stringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- Bot
Name string - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- Facebook
Application stringId - The Facebook Application ID for the Facebook Channel.
- Facebook
Application stringSecret - The Facebook Application Secret for the Facebook Channel.
- Pages
[]Channel
Facebook Page Args - One or more
page
blocks as defined below. - Resource
Group stringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- bot
Name String - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook
Application StringId - The Facebook Application ID for the Facebook Channel.
- facebook
Application StringSecret - The Facebook Application Secret for the Facebook Channel.
- pages
List<Channel
Facebook Page> - One or more
page
blocks as defined below. - resource
Group StringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- bot
Name string - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook
Application stringId - The Facebook Application ID for the Facebook Channel.
- facebook
Application stringSecret - The Facebook Application Secret for the Facebook Channel.
- pages
Channel
Facebook Page[] - One or more
page
blocks as defined below. - resource
Group stringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- bot_
name str - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook_
application_ strid - The Facebook Application ID for the Facebook Channel.
- facebook_
application_ strsecret - The Facebook Application Secret for the Facebook Channel.
- pages
Sequence[Channel
Facebook Page Args] - One or more
page
blocks as defined below. - resource_
group_ strname - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- location str
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- bot
Name String - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook
Application StringId - The Facebook Application ID for the Facebook Channel.
- facebook
Application StringSecret - The Facebook Application Secret for the Facebook Channel.
- pages List<Property Map>
- One or more
page
blocks as defined below. - resource
Group StringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
Outputs
All input properties are implicitly available as output properties. Additionally, the ChannelFacebook resource produces the following output properties:
- Id string
- The provider-assigned unique ID for this managed resource.
- Id string
- The provider-assigned unique ID for this managed resource.
- id String
- The provider-assigned unique ID for this managed resource.
- id string
- The provider-assigned unique ID for this managed resource.
- id str
- The provider-assigned unique ID for this managed resource.
- id String
- The provider-assigned unique ID for this managed resource.
Look up Existing ChannelFacebook Resource
Get an existing ChannelFacebook resource’s state with the given name, ID, and optional extra properties used to qualify the lookup.
public static get(name: string, id: Input<ID>, state?: ChannelFacebookState, opts?: CustomResourceOptions): ChannelFacebook
@staticmethod
def get(resource_name: str,
id: str,
opts: Optional[ResourceOptions] = None,
bot_name: Optional[str] = None,
facebook_application_id: Optional[str] = None,
facebook_application_secret: Optional[str] = None,
location: Optional[str] = None,
pages: Optional[Sequence[ChannelFacebookPageArgs]] = None,
resource_group_name: Optional[str] = None) -> ChannelFacebook
func GetChannelFacebook(ctx *Context, name string, id IDInput, state *ChannelFacebookState, opts ...ResourceOption) (*ChannelFacebook, error)
public static ChannelFacebook Get(string name, Input<string> id, ChannelFacebookState? state, CustomResourceOptions? opts = null)
public static ChannelFacebook get(String name, Output<String> id, ChannelFacebookState state, CustomResourceOptions options)
Resource lookup is not supported in YAML
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- resource_name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- Bot
Name string - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- Facebook
Application stringId - The Facebook Application ID for the Facebook Channel.
- Facebook
Application stringSecret - The Facebook Application Secret for the Facebook Channel.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- Pages
List<Channel
Facebook Page> - One or more
page
blocks as defined below. - Resource
Group stringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- Bot
Name string - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- Facebook
Application stringId - The Facebook Application ID for the Facebook Channel.
- Facebook
Application stringSecret - The Facebook Application Secret for the Facebook Channel.
- Location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- Pages
[]Channel
Facebook Page Args - One or more
page
blocks as defined below. - Resource
Group stringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- bot
Name String - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook
Application StringId - The Facebook Application ID for the Facebook Channel.
- facebook
Application StringSecret - The Facebook Application Secret for the Facebook Channel.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- pages
List<Channel
Facebook Page> - One or more
page
blocks as defined below. - resource
Group StringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- bot
Name string - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook
Application stringId - The Facebook Application ID for the Facebook Channel.
- facebook
Application stringSecret - The Facebook Application Secret for the Facebook Channel.
- location string
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- pages
Channel
Facebook Page[] - One or more
page
blocks as defined below. - resource
Group stringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- bot_
name str - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook_
application_ strid - The Facebook Application ID for the Facebook Channel.
- facebook_
application_ strsecret - The Facebook Application Secret for the Facebook Channel.
- location str
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- pages
Sequence[Channel
Facebook Page Args] - One or more
page
blocks as defined below. - resource_
group_ strname - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
- bot
Name String - The name of the Bot Resource this channel will be associated with. Changing this forces a new resource to be created.
- facebook
Application StringId - The Facebook Application ID for the Facebook Channel.
- facebook
Application StringSecret - The Facebook Application Secret for the Facebook Channel.
- location String
- Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.
- pages List<Property Map>
- One or more
page
blocks as defined below. - resource
Group StringName - The name of the resource group where the Facebook Channel should be created. Changing this forces a new resource to be created.
Supporting Types
ChannelFacebookPage, ChannelFacebookPageArgs
- Access
Token string - The Facebook Page Access Token for the Facebook Channel.
- Id string
- The Facebook Page ID for the Facebook Channel.
- Access
Token string - The Facebook Page Access Token for the Facebook Channel.
- Id string
- The Facebook Page ID for the Facebook Channel.
- access
Token String - The Facebook Page Access Token for the Facebook Channel.
- id String
- The Facebook Page ID for the Facebook Channel.
- access
Token string - The Facebook Page Access Token for the Facebook Channel.
- id string
- The Facebook Page ID for the Facebook Channel.
- access_
token str - The Facebook Page Access Token for the Facebook Channel.
- id str
- The Facebook Page ID for the Facebook Channel.
- access
Token String - The Facebook Page Access Token for the Facebook Channel.
- id String
- The Facebook Page ID for the Facebook Channel.
Import
The Facebook Integration for a Bot Channel can be imported using the resource id
, e.g.
$ pulumi import azure:bot/channelFacebook:ChannelFacebook example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/group1/providers/Microsoft.BotService/botServices/botService1/channels/FacebookChannel
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- Azure Classic pulumi/pulumi-azure
- License
- Apache-2.0
- Notes
- This Pulumi package is based on the
azurerm
Terraform Provider.