Output Function Args
data class OutputFunctionArgs(val apiKey: Output<String>? = null, val batchMaxCount: Output<Int>? = null, val batchMaxInBytes: Output<Int>? = null, val functionApp: Output<String>? = null, val functionName: Output<String>? = null, val name: Output<String>? = null, val resourceGroupName: Output<String>? = null, val streamAnalyticsJobName: Output<String>? = null) : ConvertibleToJava<OutputFunctionArgs>
Manages a Stream Analytics Output Function.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
name: "example-resources",
location: "West Europe",
});
const exampleAccount = new azure.storage.Account("example", {
name: "examplestorageaccount",
resourceGroupName: example.name,
location: example.location,
accountTier: "Standard",
accountReplicationType: "LRS",
});
const examplePlan = new azure.appservice.Plan("example", {
name: "exampleappserviceplan",
location: example.location,
resourceGroupName: example.name,
kind: "FunctionApp",
reserved: true,
sku: {
tier: "Dynamic",
size: "Y1",
},
});
const exampleFunctionApp = new azure.appservice.FunctionApp("example", {
name: "examplefunctionapp",
location: example.location,
resourceGroupName: example.name,
appServicePlanId: examplePlan.id,
storageAccountName: exampleAccount.name,
storageAccountAccessKey: exampleAccount.primaryAccessKey,
osType: "linux",
version: "~3",
});
const exampleJob = new azure.streamanalytics.Job("example", {
name: "examplestreamanalyticsjob",
resourceGroupName: example.name,
location: example.location,
streamingUnits: 3,
transformationQuery: ` SELECT *
INTO [YourOutputAlias]
FROM [YourInputAlias]
`,
});
const exampleOutputFunction = new azure.streamanalytics.OutputFunction("example", {
name: "exampleoutput",
resourceGroupName: exampleJob.resourceGroupName,
streamAnalyticsJobName: exampleJob.name,
functionApp: exampleFunctionApp.name,
functionName: "examplefunctionname",
apiKey: "exampleapikey",
});
Content copied to clipboard
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
name="example-resources",
location="West Europe")
example_account = azure.storage.Account("example",
name="examplestorageaccount",
resource_group_name=example.name,
location=example.location,
account_tier="Standard",
account_replication_type="LRS")
example_plan = azure.appservice.Plan("example",
name="exampleappserviceplan",
location=example.location,
resource_group_name=example.name,
kind="FunctionApp",
reserved=True,
sku={
"tier": "Dynamic",
"size": "Y1",
})
example_function_app = azure.appservice.FunctionApp("example",
name="examplefunctionapp",
location=example.location,
resource_group_name=example.name,
app_service_plan_id=example_plan.id,
storage_account_name=example_account.name,
storage_account_access_key=example_account.primary_access_key,
os_type="linux",
version="~3")
example_job = azure.streamanalytics.Job("example",
name="examplestreamanalyticsjob",
resource_group_name=example.name,
location=example.location,
streaming_units=3,
transformation_query=""" SELECT *
INTO [YourOutputAlias]
FROM [YourInputAlias]
""")
example_output_function = azure.streamanalytics.OutputFunction("example",
name="exampleoutput",
resource_group_name=example_job.resource_group_name,
stream_analytics_job_name=example_job.name,
function_app=example_function_app.name,
function_name="examplefunctionname",
api_key="exampleapikey")
Content copied to clipboard
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-resources",
Location = "West Europe",
});
var exampleAccount = new Azure.Storage.Account("example", new()
{
Name = "examplestorageaccount",
ResourceGroupName = example.Name,
Location = example.Location,
AccountTier = "Standard",
AccountReplicationType = "LRS",
});
var examplePlan = new Azure.AppService.Plan("example", new()
{
Name = "exampleappserviceplan",
Location = example.Location,
ResourceGroupName = example.Name,
Kind = "FunctionApp",
Reserved = true,
Sku = new Azure.AppService.Inputs.PlanSkuArgs
{
Tier = "Dynamic",
Size = "Y1",
},
});
var exampleFunctionApp = new Azure.AppService.FunctionApp("example", new()
{
Name = "examplefunctionapp",
Location = example.Location,
ResourceGroupName = example.Name,
AppServicePlanId = examplePlan.Id,
StorageAccountName = exampleAccount.Name,
StorageAccountAccessKey = exampleAccount.PrimaryAccessKey,
OsType = "linux",
Version = "~3",
});
var exampleJob = new Azure.StreamAnalytics.Job("example", new()
{
Name = "examplestreamanalyticsjob",
ResourceGroupName = example.Name,
Location = example.Location,
StreamingUnits = 3,
TransformationQuery = @" SELECT *
INTO [YourOutputAlias]
FROM [YourInputAlias]
",
});
var exampleOutputFunction = new Azure.StreamAnalytics.OutputFunction("example", new()
{
Name = "exampleoutput",
ResourceGroupName = exampleJob.ResourceGroupName,
StreamAnalyticsJobName = exampleJob.Name,
FunctionApp = exampleFunctionApp.Name,
FunctionName = "examplefunctionname",
ApiKey = "exampleapikey",
});
});
Content copied to clipboard
package main
import (
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/appservice"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/storage"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/streamanalytics"
"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-resources"),
Location: pulumi.String("West Europe"),
})
if err != nil {
return err
}
exampleAccount, err := storage.NewAccount(ctx, "example", &storage.AccountArgs{
Name: pulumi.String("examplestorageaccount"),
ResourceGroupName: example.Name,
Location: example.Location,
AccountTier: pulumi.String("Standard"),
AccountReplicationType: pulumi.String("LRS"),
})
if err != nil {
return err
}
examplePlan, err := appservice.NewPlan(ctx, "example", &appservice.PlanArgs{
Name: pulumi.String("exampleappserviceplan"),
Location: example.Location,
ResourceGroupName: example.Name,
Kind: pulumi.Any("FunctionApp"),
Reserved: pulumi.Bool(true),
Sku: &appservice.PlanSkuArgs{
Tier: pulumi.String("Dynamic"),
Size: pulumi.String("Y1"),
},
})
if err != nil {
return err
}
exampleFunctionApp, err := appservice.NewFunctionApp(ctx, "example", &appservice.FunctionAppArgs{
Name: pulumi.String("examplefunctionapp"),
Location: example.Location,
ResourceGroupName: example.Name,
AppServicePlanId: examplePlan.ID(),
StorageAccountName: exampleAccount.Name,
StorageAccountAccessKey: exampleAccount.PrimaryAccessKey,
OsType: pulumi.String("linux"),
Version: pulumi.String("~3"),
})
if err != nil {
return err
}
exampleJob, err := streamanalytics.NewJob(ctx, "example", &streamanalytics.JobArgs{
Name: pulumi.String("examplestreamanalyticsjob"),
ResourceGroupName: example.Name,
Location: example.Location,
StreamingUnits: pulumi.Int(3),
TransformationQuery: pulumi.String(" SELECT *\n INTO [YourOutputAlias]\n FROM [YourInputAlias]\n"),
})
if err != nil {
return err
}
_, err = streamanalytics.NewOutputFunction(ctx, "example", &streamanalytics.OutputFunctionArgs{
Name: pulumi.String("exampleoutput"),
ResourceGroupName: exampleJob.ResourceGroupName,
StreamAnalyticsJobName: exampleJob.Name,
FunctionApp: exampleFunctionApp.Name,
FunctionName: pulumi.String("examplefunctionname"),
ApiKey: pulumi.String("exampleapikey"),
})
if err != nil {
return err
}
return nil
})
}
Content copied to clipboard
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.storage.Account;
import com.pulumi.azure.storage.AccountArgs;
import com.pulumi.azure.appservice.Plan;
import com.pulumi.azure.appservice.PlanArgs;
import com.pulumi.azure.appservice.inputs.PlanSkuArgs;
import com.pulumi.azure.appservice.FunctionApp;
import com.pulumi.azure.appservice.FunctionAppArgs;
import com.pulumi.azure.streamanalytics.Job;
import com.pulumi.azure.streamanalytics.JobArgs;
import com.pulumi.azure.streamanalytics.OutputFunction;
import com.pulumi.azure.streamanalytics.OutputFunctionArgs;
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-resources")
.location("West Europe")
.build());
var exampleAccount = new Account("exampleAccount", AccountArgs.builder()
.name("examplestorageaccount")
.resourceGroupName(example.name())
.location(example.location())
.accountTier("Standard")
.accountReplicationType("LRS")
.build());
var examplePlan = new Plan("examplePlan", PlanArgs.builder()
.name("exampleappserviceplan")
.location(example.location())
.resourceGroupName(example.name())
.kind("FunctionApp")
.reserved(true)
.sku(PlanSkuArgs.builder()
.tier("Dynamic")
.size("Y1")
.build())
.build());
var exampleFunctionApp = new FunctionApp("exampleFunctionApp", FunctionAppArgs.builder()
.name("examplefunctionapp")
.location(example.location())
.resourceGroupName(example.name())
.appServicePlanId(examplePlan.id())
.storageAccountName(exampleAccount.name())
.storageAccountAccessKey(exampleAccount.primaryAccessKey())
.osType("linux")
.version("~3")
.build());
var exampleJob = new Job("exampleJob", JobArgs.builder()
.name("examplestreamanalyticsjob")
.resourceGroupName(example.name())
.location(example.location())
.streamingUnits(3)
.transformationQuery("""
SELECT *
INTO [YourOutputAlias]
FROM [YourInputAlias]
""")
.build());
var exampleOutputFunction = new OutputFunction("exampleOutputFunction", OutputFunctionArgs.builder()
.name("exampleoutput")
.resourceGroupName(exampleJob.resourceGroupName())
.streamAnalyticsJobName(exampleJob.name())
.functionApp(exampleFunctionApp.name())
.functionName("examplefunctionname")
.apiKey("exampleapikey")
.build());
}
}
Content copied to clipboard
resources:
example:
type: azure:core:ResourceGroup
properties:
name: example-resources
location: West Europe
exampleAccount:
type: azure:storage:Account
name: example
properties:
name: examplestorageaccount
resourceGroupName: ${example.name}
location: ${example.location}
accountTier: Standard
accountReplicationType: LRS
examplePlan:
type: azure:appservice:Plan
name: example
properties:
name: exampleappserviceplan
location: ${example.location}
resourceGroupName: ${example.name}
kind: FunctionApp
reserved: true
sku:
tier: Dynamic
size: Y1
exampleFunctionApp:
type: azure:appservice:FunctionApp
name: example
properties:
name: examplefunctionapp
location: ${example.location}
resourceGroupName: ${example.name}
appServicePlanId: ${examplePlan.id}
storageAccountName: ${exampleAccount.name}
storageAccountAccessKey: ${exampleAccount.primaryAccessKey}
osType: linux
version: ~3
exampleJob:
type: azure:streamanalytics:Job
name: example
properties:
name: examplestreamanalyticsjob
resourceGroupName: ${example.name}
location: ${example.location}
streamingUnits: 3
transformationQuery: |2
SELECT *
INTO [YourOutputAlias]
FROM [YourInputAlias]
exampleOutputFunction:
type: azure:streamanalytics:OutputFunction
name: example
properties:
name: exampleoutput
resourceGroupName: ${exampleJob.resourceGroupName}
streamAnalyticsJobName: ${exampleJob.name}
functionApp: ${exampleFunctionApp.name}
functionName: examplefunctionname
apiKey: exampleapikey
Content copied to clipboard
API Providers
This resource uses the following Azure API Providers:
Microsoft.StreamAnalytics
: 2021-10-01-preview
Import
Stream Analytics Output Functions can be imported using the resource id
, e.g.
$ pulumi import azure:streamanalytics/outputFunction:OutputFunction example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/group1/providers/Microsoft.StreamAnalytics/streamingJobs/job1/outputs/output1
Content copied to clipboard
Constructors
Link copied to clipboard
constructor(apiKey: Output<String>? = null, batchMaxCount: Output<Int>? = null, batchMaxInBytes: Output<Int>? = null, functionApp: Output<String>? = null, functionName: Output<String>? = null, name: Output<String>? = null, resourceGroupName: Output<String>? = null, streamAnalyticsJobName: Output<String>? = null)
Properties
Link copied to clipboard
The maximum number of events in each batch that's sent to the function. Defaults to 100
.
Link copied to clipboard
The maximum batch size in bytes that's sent to the function. Defaults to 262144
(256 kB).
Link copied to clipboard
The name of the Function App.
Link copied to clipboard
The name of the function in the Function App.
Link copied to clipboard
The name of the Resource Group where the Stream Analytics Output should exist. Changing this forces a new resource to be created.
Link copied to clipboard
The name of the Stream Analytics Job. Changing this forces a new resource to be created.