
com.pulumi.azure.sentinel.kotlin.DataConnectorAwsS3Args.kt Maven / Gradle / Ivy
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.azure.sentinel.kotlin
import com.pulumi.azure.sentinel.DataConnectorAwsS3Args.builder
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.collections.List
import kotlin.jvm.JvmName
/**
* Manages a AWS S3 Data Connector.
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as azure from "@pulumi/azure";
* const example = new azure.core.ResourceGroup("example", {
* name: "example-rg",
* location: "West Europe",
* });
* const exampleAnalyticsWorkspace = new azure.operationalinsights.AnalyticsWorkspace("example", {
* name: "example-workspace",
* location: example.location,
* resourceGroupName: example.name,
* sku: "PerGB2018",
* });
* const exampleLogAnalyticsWorkspaceOnboarding = new azure.sentinel.LogAnalyticsWorkspaceOnboarding("example", {workspaceId: exampleAnalyticsWorkspace.id});
* const exampleDataConnectorAwsS3 = new azure.sentinel.DataConnectorAwsS3("example", {
* name: "example",
* logAnalyticsWorkspaceId: exampleLogAnalyticsWorkspaceOnboarding.workspaceId,
* awsRoleArn: "arn:aws:iam::000000000000:role/role1",
* destinationTable: "AWSGuardDuty",
* sqsUrls: ["https://sqs.us-east-1.amazonaws.com/000000000000/example"],
* });
* ```
* ```python
* import pulumi
* import pulumi_azure as azure
* example = azure.core.ResourceGroup("example",
* name="example-rg",
* location="West Europe")
* example_analytics_workspace = azure.operationalinsights.AnalyticsWorkspace("example",
* name="example-workspace",
* location=example.location,
* resource_group_name=example.name,
* sku="PerGB2018")
* example_log_analytics_workspace_onboarding = azure.sentinel.LogAnalyticsWorkspaceOnboarding("example", workspace_id=example_analytics_workspace.id)
* example_data_connector_aws_s3 = azure.sentinel.DataConnectorAwsS3("example",
* name="example",
* log_analytics_workspace_id=example_log_analytics_workspace_onboarding.workspace_id,
* aws_role_arn="arn:aws:iam::000000000000:role/role1",
* destination_table="AWSGuardDuty",
* sqs_urls=["https://sqs.us-east-1.amazonaws.com/000000000000/example"])
* ```
* ```csharp
* 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-rg",
* Location = "West Europe",
* });
* var exampleAnalyticsWorkspace = new Azure.OperationalInsights.AnalyticsWorkspace("example", new()
* {
* Name = "example-workspace",
* Location = example.Location,
* ResourceGroupName = example.Name,
* Sku = "PerGB2018",
* });
* var exampleLogAnalyticsWorkspaceOnboarding = new Azure.Sentinel.LogAnalyticsWorkspaceOnboarding("example", new()
* {
* WorkspaceId = exampleAnalyticsWorkspace.Id,
* });
* var exampleDataConnectorAwsS3 = new Azure.Sentinel.DataConnectorAwsS3("example", new()
* {
* Name = "example",
* LogAnalyticsWorkspaceId = exampleLogAnalyticsWorkspaceOnboarding.WorkspaceId,
* AwsRoleArn = "arn:aws:iam::000000000000:role/role1",
* DestinationTable = "AWSGuardDuty",
* SqsUrls = new[]
* {
* "https://sqs.us-east-1.amazonaws.com/000000000000/example",
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/operationalinsights"
* "github.com/pulumi/pulumi-azure/sdk/v5/go/azure/sentinel"
* "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-rg"),
* Location: pulumi.String("West Europe"),
* })
* if err != nil {
* return err
* }
* exampleAnalyticsWorkspace, err := operationalinsights.NewAnalyticsWorkspace(ctx, "example", &operationalinsights.AnalyticsWorkspaceArgs{
* Name: pulumi.String("example-workspace"),
* Location: example.Location,
* ResourceGroupName: example.Name,
* Sku: pulumi.String("PerGB2018"),
* })
* if err != nil {
* return err
* }
* exampleLogAnalyticsWorkspaceOnboarding, err := sentinel.NewLogAnalyticsWorkspaceOnboarding(ctx, "example", &sentinel.LogAnalyticsWorkspaceOnboardingArgs{
* WorkspaceId: exampleAnalyticsWorkspace.ID(),
* })
* if err != nil {
* return err
* }
* _, err = sentinel.NewDataConnectorAwsS3(ctx, "example", &sentinel.DataConnectorAwsS3Args{
* Name: pulumi.String("example"),
* LogAnalyticsWorkspaceId: exampleLogAnalyticsWorkspaceOnboarding.WorkspaceId,
* AwsRoleArn: pulumi.String("arn:aws:iam::000000000000:role/role1"),
* DestinationTable: pulumi.String("AWSGuardDuty"),
* SqsUrls: pulumi.StringArray{
* pulumi.String("https://sqs.us-east-1.amazonaws.com/000000000000/example"),
* },
* })
* 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.azure.core.ResourceGroup;
* import com.pulumi.azure.core.ResourceGroupArgs;
* import com.pulumi.azure.operationalinsights.AnalyticsWorkspace;
* import com.pulumi.azure.operationalinsights.AnalyticsWorkspaceArgs;
* import com.pulumi.azure.sentinel.LogAnalyticsWorkspaceOnboarding;
* import com.pulumi.azure.sentinel.LogAnalyticsWorkspaceOnboardingArgs;
* import com.pulumi.azure.sentinel.DataConnectorAwsS3;
* import com.pulumi.azure.sentinel.DataConnectorAwsS3Args;
* 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-rg")
* .location("West Europe")
* .build());
* var exampleAnalyticsWorkspace = new AnalyticsWorkspace("exampleAnalyticsWorkspace", AnalyticsWorkspaceArgs.builder()
* .name("example-workspace")
* .location(example.location())
* .resourceGroupName(example.name())
* .sku("PerGB2018")
* .build());
* var exampleLogAnalyticsWorkspaceOnboarding = new LogAnalyticsWorkspaceOnboarding("exampleLogAnalyticsWorkspaceOnboarding", LogAnalyticsWorkspaceOnboardingArgs.builder()
* .workspaceId(exampleAnalyticsWorkspace.id())
* .build());
* var exampleDataConnectorAwsS3 = new DataConnectorAwsS3("exampleDataConnectorAwsS3", DataConnectorAwsS3Args.builder()
* .name("example")
* .logAnalyticsWorkspaceId(exampleLogAnalyticsWorkspaceOnboarding.workspaceId())
* .awsRoleArn("arn:aws:iam::000000000000:role/role1")
* .destinationTable("AWSGuardDuty")
* .sqsUrls("https://sqs.us-east-1.amazonaws.com/000000000000/example")
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: azure:core:ResourceGroup
* properties:
* name: example-rg
* location: West Europe
* exampleAnalyticsWorkspace:
* type: azure:operationalinsights:AnalyticsWorkspace
* name: example
* properties:
* name: example-workspace
* location: ${example.location}
* resourceGroupName: ${example.name}
* sku: PerGB2018
* exampleLogAnalyticsWorkspaceOnboarding:
* type: azure:sentinel:LogAnalyticsWorkspaceOnboarding
* name: example
* properties:
* workspaceId: ${exampleAnalyticsWorkspace.id}
* exampleDataConnectorAwsS3:
* type: azure:sentinel:DataConnectorAwsS3
* name: example
* properties:
* name: example
* logAnalyticsWorkspaceId: ${exampleLogAnalyticsWorkspaceOnboarding.workspaceId}
* awsRoleArn: arn:aws:iam::000000000000:role/role1
* destinationTable: AWSGuardDuty
* sqsUrls:
* - https://sqs.us-east-1.amazonaws.com/000000000000/example
* ```
*
* ## Import
* AWS S3 Data Connectors can be imported using the `resource id`, e.g.
* ```sh
* $ pulumi import azure:sentinel/dataConnectorAwsS3:DataConnectorAwsS3 example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/group1/providers/Microsoft.OperationalInsights/workspaces/workspace1/providers/Microsoft.SecurityInsights/dataConnectors/dc1
* ```
* @property awsRoleArn The ARN of the AWS role, which is connected to this AWS CloudTrail Data Connector. See the [Azure document](https://docs.microsoft.com/azure/sentinel/connect-aws?tabs=s3#create-an-aws-assumed-role-and-grant-access-to-the-aws-sentinel-account) for details.
* @property destinationTable The name of the Log Analytics table that will store the ingested data.
* @property logAnalyticsWorkspaceId The ID of the Log Analytics Workspace that this AWS S3 Data Connector resides in. Changing this forces a new AWS S3 Data Connector to be created.
* @property name The name which should be used for this AWS S3 Data Connector. Changing this forces a new AWS S3 Data Connector to be created.
* @property sqsUrls Specifies a list of AWS SQS urls for the AWS S3 Data Connector.
*/
public data class DataConnectorAwsS3Args(
public val awsRoleArn: Output? = null,
public val destinationTable: Output? = null,
public val logAnalyticsWorkspaceId: Output? = null,
public val name: Output? = null,
public val sqsUrls: Output>? = null,
) : ConvertibleToJava {
override fun toJava(): com.pulumi.azure.sentinel.DataConnectorAwsS3Args =
com.pulumi.azure.sentinel.DataConnectorAwsS3Args.builder()
.awsRoleArn(awsRoleArn?.applyValue({ args0 -> args0 }))
.destinationTable(destinationTable?.applyValue({ args0 -> args0 }))
.logAnalyticsWorkspaceId(logAnalyticsWorkspaceId?.applyValue({ args0 -> args0 }))
.name(name?.applyValue({ args0 -> args0 }))
.sqsUrls(sqsUrls?.applyValue({ args0 -> args0.map({ args0 -> args0 }) })).build()
}
/**
* Builder for [DataConnectorAwsS3Args].
*/
@PulumiTagMarker
public class DataConnectorAwsS3ArgsBuilder internal constructor() {
private var awsRoleArn: Output? = null
private var destinationTable: Output? = null
private var logAnalyticsWorkspaceId: Output? = null
private var name: Output? = null
private var sqsUrls: Output>? = null
/**
* @param value The ARN of the AWS role, which is connected to this AWS CloudTrail Data Connector. See the [Azure document](https://docs.microsoft.com/azure/sentinel/connect-aws?tabs=s3#create-an-aws-assumed-role-and-grant-access-to-the-aws-sentinel-account) for details.
*/
@JvmName("gluektugyyfsupua")
public suspend fun awsRoleArn(`value`: Output) {
this.awsRoleArn = value
}
/**
* @param value The name of the Log Analytics table that will store the ingested data.
*/
@JvmName("poyhqcvrjvdtisrs")
public suspend fun destinationTable(`value`: Output) {
this.destinationTable = value
}
/**
* @param value The ID of the Log Analytics Workspace that this AWS S3 Data Connector resides in. Changing this forces a new AWS S3 Data Connector to be created.
*/
@JvmName("iamssydwdxwdfssj")
public suspend fun logAnalyticsWorkspaceId(`value`: Output) {
this.logAnalyticsWorkspaceId = value
}
/**
* @param value The name which should be used for this AWS S3 Data Connector. Changing this forces a new AWS S3 Data Connector to be created.
*/
@JvmName("bjjwwcswtcdbeuno")
public suspend fun name(`value`: Output) {
this.name = value
}
/**
* @param value Specifies a list of AWS SQS urls for the AWS S3 Data Connector.
*/
@JvmName("opnxrqawameocuxn")
public suspend fun sqsUrls(`value`: Output>) {
this.sqsUrls = value
}
@JvmName("uuoiimallvcsmsxy")
public suspend fun sqsUrls(vararg values: Output) {
this.sqsUrls = Output.all(values.asList())
}
/**
* @param values Specifies a list of AWS SQS urls for the AWS S3 Data Connector.
*/
@JvmName("xixdgtfhddyguxwg")
public suspend fun sqsUrls(values: List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy