Customizable Connector Definition
Connector definition for kind 'Customizable'. Uses Azure REST API version 2024-09-01. In version 2.x of the Azure Native provider, it used API version 2023-07-01-preview.
Example Usage
Create data connector definition
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using AzureNative = Pulumi.AzureNative;
return await Deployment.RunAsync(() =>
{
var customizableConnectorDefinition = new AzureNative.SecurityInsights.CustomizableConnectorDefinition("customizableConnectorDefinition", new()
{
ConnectorUiConfig = new AzureNative.SecurityInsights.Inputs.CustomizableConnectorUiConfigArgs
{
Availability = new AzureNative.SecurityInsights.Inputs.ConnectorDefinitionsAvailabilityArgs
{
IsPreview = false,
Status = 1,
},
ConnectivityCriteria = new[]
{
new AzureNative.SecurityInsights.Inputs.ConnectivityCriterionArgs
{
Type = "IsConnectedQuery",
Value = new[]
{
@"GitHubAuditLogPolling_CL
| summarize LastLogReceived = max(TimeGenerated)
| project IsConnected = LastLogReceived ago(30d)",
},
},
},
DataTypes = new[]
{
new AzureNative.SecurityInsights.Inputs.ConnectorDataTypeArgs
{
LastDataReceivedQuery = @"GitHubAuditLogPolling_CL
| summarize Time = max(TimeGenerated)
| where isnotempty(Time)",
Name = "GitHubAuditLogPolling_CL",
},
},
DescriptionMarkdown = "The GitHub audit log connector provides the capability to ingest GitHub logs into Azure Sentinel. By connecting GitHub audit logs into Azure Sentinel, you can view this data in workbooks, use it to create custom alerts, and improve your investigation process.",
GraphQueries = new[]
{
new AzureNative.SecurityInsights.Inputs.GraphQueryArgs
{
BaseQuery = "GitHubAuditLogPolling_CL",
Legend = "GitHub audit log events",
MetricName = "Total events received",
},
},
InstructionSteps = new[]
{
new AzureNative.SecurityInsights.Inputs.InstructionStepArgs
{
Description = @"Enable GitHub audit Logs.
Follow [this](https://docs.github.com/en/github/authenticating-to-github/keeping-your-account-and-data-secure/creating-a-personal-access-token) to create or find your personal key",
Instructions = new[]
{
new AzureNative.SecurityInsights.Inputs.InstructionStepDetailsArgs
{
Parameters = new Dictionary<string, object?>
{
["clientIdLabel"] = "Client ID",
["clientSecretLabel"] = "Client Secret",
["connectButtonLabel"] = "Connect",
["disconnectButtonLabel"] = "Disconnect",
},
Type = "OAuthForm",
},
},
Title = "Connect GitHub Enterprise Audit Log to Azure Sentinel",
},
},
Permissions = new AzureNative.SecurityInsights.Inputs.ConnectorDefinitionsPermissionsArgs
{
Customs = new[]
{
new AzureNative.SecurityInsights.Inputs.CustomPermissionDetailsArgs
{
Description = "You need access to GitHub personal token, the key should have 'admin:org' scope",
Name = "GitHub API personal token Key",
},
},
ResourceProvider = new[]
{
new AzureNative.SecurityInsights.Inputs.ConnectorDefinitionsResourceProviderArgs
{
PermissionsDisplayText = "read and write permissions are required.",
Provider = "Microsoft.OperationalInsights/workspaces",
ProviderDisplayName = "Workspace",
RequiredPermissions = new AzureNative.SecurityInsights.Inputs.ResourceProviderRequiredPermissionsArgs
{
Action = false,
Delete = false,
Read = false,
Write = true,
},
Scope = AzureNative.SecurityInsights.ProviderPermissionsScope.Workspace,
},
},
},
Publisher = "GitHub",
Title = "GitHub Enterprise Audit Log",
},
DataConnectorDefinitionName = "73e01a99-5cd7-4139-a149-9f2736ff2ab5",
Kind = "Customizable",
ResourceGroupName = "myRg",
WorkspaceName = "myWorkspace",
});
});
Content copied to clipboard
package main
import (
securityinsights "github.com/pulumi/pulumi-azure-native-sdk/securityinsights/v3"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := securityinsights.NewCustomizableConnectorDefinition(ctx, "customizableConnectorDefinition", &securityinsights.CustomizableConnectorDefinitionArgs{
ConnectorUiConfig: &securityinsights.CustomizableConnectorUiConfigArgs{
Availability: &securityinsights.ConnectorDefinitionsAvailabilityArgs{
IsPreview: pulumi.Bool(false),
Status: pulumi.Int(1),
},
ConnectivityCriteria: securityinsights.ConnectivityCriterionArray{
&securityinsights.ConnectivityCriterionArgs{
Type: pulumi.String("IsConnectedQuery"),
Value: pulumi.StringArray{
pulumi.String("GitHubAuditLogPolling_CL \n | summarize LastLogReceived = max(TimeGenerated)\n | project IsConnected = LastLogReceived ago(30d)"),
},
},
},
DataTypes: securityinsights.ConnectorDataTypeArray{
&securityinsights.ConnectorDataTypeArgs{
LastDataReceivedQuery: pulumi.String("GitHubAuditLogPolling_CL \n | summarize Time = max(TimeGenerated)\n | where isnotempty(Time)"),
Name: pulumi.String("GitHubAuditLogPolling_CL"),
},
},
DescriptionMarkdown: pulumi.String("The GitHub audit log connector provides the capability to ingest GitHub logs into Azure Sentinel. By connecting GitHub audit logs into Azure Sentinel, you can view this data in workbooks, use it to create custom alerts, and improve your investigation process."),
GraphQueries: securityinsights.GraphQueryArray{
&securityinsights.GraphQueryArgs{
BaseQuery: pulumi.String("GitHubAuditLogPolling_CL"),
Legend: pulumi.String("GitHub audit log events"),
MetricName: pulumi.String("Total events received"),
},
},
InstructionSteps: securityinsights.InstructionStepArray{
&securityinsights.InstructionStepArgs{
Description: pulumi.String("Enable GitHub audit Logs. \n Follow [this](https://docs.github.com/en/github/authenticating-to-github/keeping-your-account-and-data-secure/creating-a-personal-access-token) to create or find your personal key"),
Instructions: securityinsights.InstructionStepDetailsArray{
&securityinsights.InstructionStepDetailsArgs{
Parameters: pulumi.Any(map[string]interface{}{
"clientIdLabel": "Client ID",
"clientSecretLabel": "Client Secret",
"connectButtonLabel": "Connect",
"disconnectButtonLabel": "Disconnect",
}),
Type: pulumi.String("OAuthForm"),
},
},
Title: pulumi.String("Connect GitHub Enterprise Audit Log to Azure Sentinel"),
},
},
Permissions: &securityinsights.ConnectorDefinitionsPermissionsArgs{
Customs: securityinsights.CustomPermissionDetailsArray{
&securityinsights.CustomPermissionDetailsArgs{
Description: pulumi.String("You need access to GitHub personal token, the key should have 'admin:org' scope"),
Name: pulumi.String("GitHub API personal token Key"),
},
},
ResourceProvider: securityinsights.ConnectorDefinitionsResourceProviderArray{
&securityinsights.ConnectorDefinitionsResourceProviderArgs{
PermissionsDisplayText: pulumi.String("read and write permissions are required."),
Provider: pulumi.String("Microsoft.OperationalInsights/workspaces"),
ProviderDisplayName: pulumi.String("Workspace"),
RequiredPermissions: &securityinsights.ResourceProviderRequiredPermissionsArgs{
Action: pulumi.Bool(false),
Delete: pulumi.Bool(false),
Read: pulumi.Bool(false),
Write: pulumi.Bool(true),
},
Scope: pulumi.String(securityinsights.ProviderPermissionsScopeWorkspace),
},
},
},
Publisher: pulumi.String("GitHub"),
Title: pulumi.String("GitHub Enterprise Audit Log"),
},
DataConnectorDefinitionName: pulumi.String("73e01a99-5cd7-4139-a149-9f2736ff2ab5"),
Kind: pulumi.String("Customizable"),
ResourceGroupName: pulumi.String("myRg"),
WorkspaceName: pulumi.String("myWorkspace"),
})
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.azurenative.securityinsights.CustomizableConnectorDefinition;
import com.pulumi.azurenative.securityinsights.CustomizableConnectorDefinitionArgs;
import com.pulumi.azurenative.securityinsights.inputs.CustomizableConnectorUiConfigArgs;
import com.pulumi.azurenative.securityinsights.inputs.ConnectorDefinitionsAvailabilityArgs;
import com.pulumi.azurenative.securityinsights.inputs.ConnectorDefinitionsPermissionsArgs;
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 customizableConnectorDefinition = new CustomizableConnectorDefinition("customizableConnectorDefinition", CustomizableConnectorDefinitionArgs.builder()
.connectorUiConfig(CustomizableConnectorUiConfigArgs.builder()
.availability(ConnectorDefinitionsAvailabilityArgs.builder()
.isPreview(false)
.status(1)
.build())
.connectivityCriteria(ConnectivityCriterionArgs.builder()
.type("IsConnectedQuery")
.value("""
GitHubAuditLogPolling_CL
| summarize LastLogReceived = max(TimeGenerated)
| project IsConnected = LastLogReceived ago(30d) """)
.build())
.dataTypes(ConnectorDataTypeArgs.builder()
.lastDataReceivedQuery("""
GitHubAuditLogPolling_CL
| summarize Time = max(TimeGenerated)
| where isnotempty(Time) """)
.name("GitHubAuditLogPolling_CL")
.build())
.descriptionMarkdown("The GitHub audit log connector provides the capability to ingest GitHub logs into Azure Sentinel. By connecting GitHub audit logs into Azure Sentinel, you can view this data in workbooks, use it to create custom alerts, and improve your investigation process.")
.graphQueries(GraphQueryArgs.builder()
.baseQuery("GitHubAuditLogPolling_CL")
.legend("GitHub audit log events")
.metricName("Total events received")
.build())
.instructionSteps(InstructionStepArgs.builder()
.description("""
Enable GitHub audit Logs.
Follow [this](https://docs.github.com/en/github/authenticating-to-github/keeping-your-account-and-data-secure/creating-a-personal-access-token) to create or find your personal key """)
.instructions(InstructionStepDetailsArgs.builder()
.parameters(Map.ofEntries(
Map.entry("clientIdLabel", "Client ID"),
Map.entry("clientSecretLabel", "Client Secret"),
Map.entry("connectButtonLabel", "Connect"),
Map.entry("disconnectButtonLabel", "Disconnect")
))
.type("OAuthForm")
.build())
.title("Connect GitHub Enterprise Audit Log to Azure Sentinel")
.build())
.permissions(ConnectorDefinitionsPermissionsArgs.builder()
.customs(CustomPermissionDetailsArgs.builder()
.description("You need access to GitHub personal token, the key should have 'admin:org' scope")
.name("GitHub API personal token Key")
.build())
.resourceProvider(ConnectorDefinitionsResourceProviderArgs.builder()
.permissionsDisplayText("read and write permissions are required.")
.provider("Microsoft.OperationalInsights/workspaces")
.providerDisplayName("Workspace")
.requiredPermissions(ResourceProviderRequiredPermissionsArgs.builder()
.action(false)
.delete(false)
.read(false)
.write(true)
.build())
.scope("Workspace")
.build())
.build())
.publisher("GitHub")
.title("GitHub Enterprise Audit Log")
.build())
.dataConnectorDefinitionName("73e01a99-5cd7-4139-a149-9f2736ff2ab5")
.kind("Customizable")
.resourceGroupName("myRg")
.workspaceName("myWorkspace")
.build());
}
}
Content copied to clipboard
Import
An existing resource can be imported using its type token, name, and identifier, e.g.
$ pulumi import azure-native:securityinsights:CustomizableConnectorDefinition 73e01a99-5cd7-4139-a149-9f2736ff2ab5 /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.OperationalInsights/workspaces/{workspaceName}/providers/Microsoft.SecurityInsights/dataConnectorDefinitions/{dataConnectorDefinitionName}
Content copied to clipboard
Properties
Link copied to clipboard
The Azure API version of the resource.
Link copied to clipboard
The UiConfig for 'Customizable' connector definition kind.
Link copied to clipboard
The UiConfig for 'Customizable' connector definition kind.
Link copied to clipboard
Gets or sets the connector definition created date in UTC format.
Link copied to clipboard
Gets or sets the connector definition last modified date in UTC format.
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard
Azure Resource Manager metadata containing createdBy and modifiedBy information.