All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pulumi.azurenative.streamanalytics.kotlin.FunctionArgs.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 2.82.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.azurenative.streamanalytics.kotlin

import com.pulumi.azurenative.streamanalytics.FunctionArgs.builder
import com.pulumi.azurenative.streamanalytics.kotlin.inputs.AggregateFunctionPropertiesArgs
import com.pulumi.azurenative.streamanalytics.kotlin.inputs.ScalarFunctionPropertiesArgs
import com.pulumi.core.Either
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import kotlin.String
import kotlin.Suppress
import kotlin.jvm.JvmName

/**
 * A function object, containing all information associated with the named function. All functions are contained under a streaming job.
 * Azure REST API version: 2020-03-01. Prior API version in Azure Native 1.x: 2016-03-01.
 * Other available API versions: 2016-03-01, 2021-10-01-preview.
 * ## Example Usage
 * ### Create a JavaScript function
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using AzureNative = Pulumi.AzureNative;
 * return await Deployment.RunAsync(() =>
 * {
 *     var function = new AzureNative.StreamAnalytics.Function("function", new()
 *     {
 *         FunctionName = "function8197",
 *         JobName = "sj8653",
 *         Properties = new AzureNative.StreamAnalytics.Inputs.ScalarFunctionPropertiesArgs
 *         {
 *             Binding = new AzureNative.StreamAnalytics.Inputs.JavaScriptFunctionBindingArgs
 *             {
 *                 Script = "function (x, y) { return x + y; }",
 *                 Type = "Microsoft.StreamAnalytics/JavascriptUdf",
 *             },
 *             Inputs = new[]
 *             {
 *                 new AzureNative.StreamAnalytics.Inputs.FunctionInputArgs
 *                 {
 *                     DataType = "Any",
 *                 },
 *             },
 *             Output = new AzureNative.StreamAnalytics.Inputs.FunctionOutputArgs
 *             {
 *                 DataType = "Any",
 *             },
 *             Type = "Scalar",
 *         },
 *         ResourceGroupName = "sjrg1637",
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	streamanalytics "github.com/pulumi/pulumi-azure-native-sdk/streamanalytics/v2"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := streamanalytics.NewFunction(ctx, "function", &streamanalytics.FunctionArgs{
 * 			FunctionName: pulumi.String("function8197"),
 * 			JobName:      pulumi.String("sj8653"),
 * 			Properties: &streamanalytics.ScalarFunctionPropertiesArgs{
 * 				Binding: streamanalytics.JavaScriptFunctionBinding{
 * 					Script: "function (x, y) { return x + y; }",
 * 					Type:   "Microsoft.StreamAnalytics/JavascriptUdf",
 * 				},
 * 				Inputs: streamanalytics.FunctionInputTypeArray{
 * 					&streamanalytics.FunctionInputTypeArgs{
 * 						DataType: pulumi.String("Any"),
 * 					},
 * 				},
 * 				Output: &streamanalytics.FunctionOutputTypeArgs{
 * 					DataType: pulumi.String("Any"),
 * 				},
 * 				Type: pulumi.String("Scalar"),
 * 			},
 * 			ResourceGroupName: pulumi.String("sjrg1637"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.azurenative.streamanalytics.Function;
 * import com.pulumi.azurenative.streamanalytics.FunctionArgs;
 * 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 function = new Function("function", FunctionArgs.builder()
 *             .functionName("function8197")
 *             .jobName("sj8653")
 *             .properties(ScalarFunctionPropertiesArgs.builder()
 *                 .binding(AzureMachineLearningWebServiceFunctionBindingArgs.builder()
 *                     .script("function (x, y) { return x + y; }")
 *                     .type("Microsoft.StreamAnalytics/JavascriptUdf")
 *                     .build())
 *                 .inputs(FunctionInputArgs.builder()
 *                     .dataType("Any")
 *                     .build())
 *                 .output(FunctionOutputArgs.builder()
 *                     .dataType("Any")
 *                     .build())
 *                 .type("Scalar")
 *                 .build())
 *             .resourceGroupName("sjrg1637")
 *             .build());
 *     }
 * }
 * ```
 * ### Create an Azure ML function
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using AzureNative = Pulumi.AzureNative;
 * return await Deployment.RunAsync(() =>
 * {
 *     var function = new AzureNative.StreamAnalytics.Function("function", new()
 *     {
 *         FunctionName = "function588",
 *         JobName = "sj9093",
 *         Properties = new AzureNative.StreamAnalytics.Inputs.ScalarFunctionPropertiesArgs
 *         {
 *             Binding = new AzureNative.StreamAnalytics.Inputs.AzureMachineLearningWebServiceFunctionBindingArgs
 *             {
 *                 ApiKey = "someApiKey==",
 *                 BatchSize = 1000,
 *                 Endpoint = "someAzureMLEndpointURL",
 *                 Inputs = new AzureNative.StreamAnalytics.Inputs.AzureMachineLearningWebServiceInputsArgs
 *                 {
 *                     ColumnNames = new[]
 *                     {
 *                         new AzureNative.StreamAnalytics.Inputs.AzureMachineLearningWebServiceInputColumnArgs
 *                         {
 *                             DataType = "string",
 *                             MapTo = 0,
 *                             Name = "tweet",
 *                         },
 *                     },
 *                     Name = "input1",
 *                 },
 *                 Outputs = new[]
 *                 {
 *                     new AzureNative.StreamAnalytics.Inputs.AzureMachineLearningWebServiceOutputColumnArgs
 *                     {
 *                         DataType = "string",
 *                         Name = "Sentiment",
 *                     },
 *                 },
 *                 Type = "Microsoft.MachineLearning/WebService",
 *             },
 *             Inputs = new[]
 *             {
 *                 new AzureNative.StreamAnalytics.Inputs.FunctionInputArgs
 *                 {
 *                     DataType = "nvarchar(max)",
 *                 },
 *             },
 *             Output = new AzureNative.StreamAnalytics.Inputs.FunctionOutputArgs
 *             {
 *                 DataType = "nvarchar(max)",
 *             },
 *             Type = "Scalar",
 *         },
 *         ResourceGroupName = "sjrg7",
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	streamanalytics "github.com/pulumi/pulumi-azure-native-sdk/streamanalytics/v2"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := streamanalytics.NewFunction(ctx, "function", &streamanalytics.FunctionArgs{
 * 			FunctionName: pulumi.String("function588"),
 * 			JobName:      pulumi.String("sj9093"),
 * 			Properties: &streamanalytics.ScalarFunctionPropertiesArgs{
 * 				Binding: streamanalytics.AzureMachineLearningWebServiceFunctionBinding{
 * 					ApiKey:    "someApiKey==",
 * 					BatchSize: 1000,
 * 					Endpoint:  "someAzureMLEndpointURL",
 * 					Inputs: streamanalytics.AzureMachineLearningWebServiceInputs{
 * 						ColumnNames: []streamanalytics.AzureMachineLearningWebServiceInputColumn{
 * 							{
 * 								DataType: "string",
 * 								MapTo:    0,
 * 								Name:     "tweet",
 * 							},
 * 						},
 * 						Name: "input1",
 * 					},
 * 					Outputs: []streamanalytics.AzureMachineLearningWebServiceOutputColumn{
 * 						{
 * 							DataType: "string",
 * 							Name:     "Sentiment",
 * 						},
 * 					},
 * 					Type: "Microsoft.MachineLearning/WebService",
 * 				},
 * 				Inputs: streamanalytics.FunctionInputTypeArray{
 * 					&streamanalytics.FunctionInputTypeArgs{
 * 						DataType: pulumi.String("nvarchar(max)"),
 * 					},
 * 				},
 * 				Output: &streamanalytics.FunctionOutputTypeArgs{
 * 					DataType: pulumi.String("nvarchar(max)"),
 * 				},
 * 				Type: pulumi.String("Scalar"),
 * 			},
 * 			ResourceGroupName: pulumi.String("sjrg7"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.azurenative.streamanalytics.Function;
 * import com.pulumi.azurenative.streamanalytics.FunctionArgs;
 * 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 function = new Function("function", FunctionArgs.builder()
 *             .functionName("function588")
 *             .jobName("sj9093")
 *             .properties(ScalarFunctionPropertiesArgs.builder()
 *                 .binding(AzureMachineLearningWebServiceFunctionBindingArgs.builder()
 *                     .apiKey("someApiKey==")
 *                     .batchSize(1000)
 *                     .endpoint("someAzureMLEndpointURL")
 *                     .inputs(AzureMachineLearningWebServiceInputsArgs.builder()
 *                         .columnNames(AzureMachineLearningWebServiceInputColumnArgs.builder()
 *                             .dataType("string")
 *                             .mapTo(0)
 *                             .name("tweet")
 *                             .build())
 *                         .name("input1")
 *                         .build())
 *                     .outputs(AzureMachineLearningWebServiceOutputColumnArgs.builder()
 *                         .dataType("string")
 *                         .name("Sentiment")
 *                         .build())
 *                     .type("Microsoft.MachineLearning/WebService")
 *                     .build())
 *                 .inputs(FunctionInputArgs.builder()
 *                     .dataType("nvarchar(max)")
 *                     .build())
 *                 .output(FunctionOutputArgs.builder()
 *                     .dataType("nvarchar(max)")
 *                     .build())
 *                 .type("Scalar")
 *                 .build())
 *             .resourceGroupName("sjrg7")
 *             .build());
 *     }
 * }
 * ```
 * ## Import
 * An existing resource can be imported using its type token, name, and identifier, e.g.
 * ```sh
 * $ pulumi import azure-native:streamanalytics:Function function588 /subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.StreamAnalytics/streamingjobs/{jobName}/functions/{functionName}
 * ```
 * @property functionName The name of the function.
 * @property jobName The name of the streaming job.
 * @property name Resource name
 * @property properties The properties that are associated with a function.
 * @property resourceGroupName The name of the resource group. The name is case insensitive.
 */
public data class FunctionArgs(
    public val functionName: Output? = null,
    public val jobName: Output? = null,
    public val name: Output? = null,
    public val properties: Output>? = null,
    public val resourceGroupName: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.azurenative.streamanalytics.FunctionArgs =
        com.pulumi.azurenative.streamanalytics.FunctionArgs.builder()
            .functionName(functionName?.applyValue({ args0 -> args0 }))
            .jobName(jobName?.applyValue({ args0 -> args0 }))
            .name(name?.applyValue({ args0 -> args0 }))
            .properties(
                properties?.applyValue({ args0 ->
                    args0.transform({ args0 ->
                        args0.let({ args0 ->
                            args0.toJava()
                        })
                    }, { args0 -> args0.let({ args0 -> args0.toJava() }) })
                }),
            )
            .resourceGroupName(resourceGroupName?.applyValue({ args0 -> args0 })).build()
}

/**
 * Builder for [FunctionArgs].
 */
@PulumiTagMarker
public class FunctionArgsBuilder internal constructor() {
    private var functionName: Output? = null

    private var jobName: Output? = null

    private var name: Output? = null

    private var properties:
        Output>? = null

    private var resourceGroupName: Output? = null

    /**
     * @param value The name of the function.
     */
    @JvmName("ixspmvjfssaiputy")
    public suspend fun functionName(`value`: Output) {
        this.functionName = value
    }

    /**
     * @param value The name of the streaming job.
     */
    @JvmName("qdtdfisklduqekpv")
    public suspend fun jobName(`value`: Output) {
        this.jobName = value
    }

    /**
     * @param value Resource name
     */
    @JvmName("qyxpiivlcxtgryca")
    public suspend fun name(`value`: Output) {
        this.name = value
    }

    /**
     * @param value The properties that are associated with a function.
     */
    @JvmName("clkasacspksdmswl")
    public suspend fun properties(`value`: Output>) {
        this.properties = value
    }

    /**
     * @param value The name of the resource group. The name is case insensitive.
     */
    @JvmName("bkpvpxdohpxgycwr")
    public suspend fun resourceGroupName(`value`: Output) {
        this.resourceGroupName = value
    }

    /**
     * @param value The name of the function.
     */
    @JvmName("rfkrtdxeyotxtihi")
    public suspend fun functionName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.functionName = mapped
    }

    /**
     * @param value The name of the streaming job.
     */
    @JvmName("xmiptwkwncevsbca")
    public suspend fun jobName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.jobName = mapped
    }

    /**
     * @param value Resource name
     */
    @JvmName("qiwlqnxoilgmevat")
    public suspend fun name(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.name = mapped
    }

    /**
     * @param value The properties that are associated with a function.
     */
    @JvmName("juipyvlqomjlhkth")
    public suspend fun properties(`value`: Either?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.properties = mapped
    }

    /**
     * @param value The properties that are associated with a function.
     */
    @JvmName("hiknlngfppaaxyjl")
    public fun properties(`value`: AggregateFunctionPropertiesArgs) {
        val toBeMapped = Either.ofLeft<
            AggregateFunctionPropertiesArgs,
            ScalarFunctionPropertiesArgs,
            >(value)
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.properties = mapped
    }

    /**
     * @param value The properties that are associated with a function.
     */
    @JvmName("qfspmaatjvpfehay")
    public fun properties(`value`: ScalarFunctionPropertiesArgs) {
        val toBeMapped = Either.ofRight<
            AggregateFunctionPropertiesArgs,
            ScalarFunctionPropertiesArgs,
            >(value)
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.properties = mapped
    }

    /**
     * @param value The name of the resource group. The name is case insensitive.
     */
    @JvmName("gfhsqdldpfrkctby")
    public suspend fun resourceGroupName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.resourceGroupName = mapped
    }

    internal fun build(): FunctionArgs = FunctionArgs(
        functionName = functionName,
        jobName = jobName,
        name = name,
        properties = properties,
        resourceGroupName = resourceGroupName,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy