Skip to content

Microsoft XDR

  • Search feature
  • Export feature
    • Remove detection rules
    • Disable detection rules
  • MSSP feature
    • Search in multiple tenants
    • Export in multiple tenants
  • Detection rule actions
    • forceUserPasswordReset
    • disableUser
    • markUserAsCompromised
    • stopAndQuarantineFile
    • restrictAppExecution
    • initiateInvestigation
    • runAntivirusScan
    • collectInvestigationPackage
    • isolateDevice
    • blockFile
    • allowFile

Limitations

Since the PySigma backend pySigma-backend-kusto does not yet support correlation rules only standard sigma and raw rules are supported.

Authentication

Two authentication mode are supported:

  • default: Default authentication via az login
  • app: Azure Registration App

When using the default authentication:

  1. Head to portal.azure.com and authenticate using MFA
  2. Use az cli to fetch the authentication session

When using the Azure Registation App, load the following environment variables:

  • DROID_AZURE_TENANT_ID: Azure tenant ID
  • DROID_AZURE_CLIENT_ID: Client ID of the registration app
  • DROID_AZURE_CLIENT_SECRET: Azure client secret

Alternatively you can add a credential file config to the toml file:

[platforms]
[platforms.microsoft_xdr]
credential_file = "microsoft365defender-authentication.yml"

The file should look like this:

client_id: 123456
client_secret: 123456
tenant_id: 123456

This will take precedence over the environment variables.

For certificate-based authentication, you can add the following configuration:

[platforms]
[platforms.microsoft_xdr]
auth_cert = "your_cert_file.pem"

Replace your_cert_file.pem with the path to your certificate file. This method will use the provided certificate for authentication. The certificate password is only needed if the private key. To provide a password you can use the environment variable DROID_AZURE_CERT_PASS or use cert_pass: "password" in the credential file.

Note

The PEM file specified in the auth_cert configuration must contain both the private key and the public key, as the public key is used for fingerprinting purposes.

The keys workspace_id and workspace_name are the base workspace declaration but this values can be replaced with the environments DROID_AZURE_WORKSPACE_ID and DROID_AZURE_WORKSPACE_NAME.

Note

When using the default authentication, set the tenant_id in the configuration

Permissions

The required permissions for the app registration are the following:

Microsoft Graph Type Description
CustomDetection.ReadWrite.All Application Read and write all custom detection rules
ThreatHunting.Read.All Application Run hunting queries

Supported Platforms

Both Sigma and raw rules are supported under the platform name microsoft_xdr.

Main config

Parameter Mandatory Default Value Description
search_auth Yes N/A Authentication method: "app" or "default"
export_auth Yes N/A Authentication method: "app" or "default"
days_ago No 1 The lookback period time when using the search feature expressed in days (from 1 to 30)
query_period Yes N/A The period of time the query should run over. Accepted Values are: 1h, 3h, 12h, 24h or 0 for near realtime, however this only works on quick queries, Sigma queries should always be OK, but RAW rules might not work
alert_prefix No None Prefix for the exported rule name
tenant_id No None Tenant ID when using "default"
credential_file No None A YAML file with your credentials if you do not want to use the environment variables
auth_cert No None A certificate file (PEM) when using the certificate-based authentication
[platforms]
[platforms.microsoft_xdr]

search_auth = "app"
export_auth = "app"
query_period = "1h"
days_ago = 3
alert_prefix = "SIGMA"

[platforms.microsoft_xdr.pipelines.process_creation]
pipelines = ["pipelines/xdr_process_creation.yml", "microsoft_xdr"]
product = "windows"
category = "process_creation"
...

Sigma Custom Fields

Custom Field Values Description
disabled true/false Set to true if you want to disable the rule
removed true/false Set to true if you want to delete the rule
action list The actions that should be performed on rule trigger, see action section for more information
impactedAssets list The impactedAssets are needed for Asset mapping to the alerts. Defaults to Device = deviceId

Action

An identifier is required for all actions. However, the script will automatically add the necessary fields to the query for actions with only one selection.

Action Identifier Isolation Type Device Group
forceUserPasswordReset accountSid, initiatingProcessAccountSid
disableUser accountSid, initiatingProcessAccountSid
markUserAsCompromised accountObjectId, initiatingProcessAccountObjectId
stopAndQuarantineFile sha1, initiatingProcessSHA1
restrictAppExecution
initiateInvestigation
runAntivirusScan
collectInvestigationPackage
isolateDevice selective, full
blockFile sha256, sha1, initiatingProcessSHA1, initiatingProcessSHA256 List of Device Groups
allowFile sha256, sha1, initiatingProcessSHA1, initiatingProcessSHA256 List of Device Groups
Danger

Never add both "block" and "allow" files simultaneously, as this can cause significant issues.

custom:
  disabled: false
  actions:
    - action: forceUserPasswordReset
      identifier: accountSid #accountSid, initiatingProcessAccountSid
    - action: disableUser
      identifier: initiatingProcessAccountSid #accountSid, initiatingProcessAccountSid
    - action: markUserAsCompromised
      identifier: initiatingProcessAccountObjectId #accountObjectId, initiatingProcessAccountObjectId
    - action: stopAndQuarantineFile
      identifier: initiatingProcessSHA1 # sha1, initiatingProcessSHA1
    - action: restrictAppExecution
    - action: initiateInvestigation
    - action: runAntivirusScan
    - action: collectInvestigationPackage
    - action: isolateDevice
      isolationType: selective # full, selective

    ## Allow or Block file, never both!
    - action: blockFile
      deviceGroupNames:
      identifier: initiatingProcessSHA256 # sha256, sha1, initiatingProcessSHA1, initiatingProcessSHA256
    #- action: allowFile
    #  deviceGroupNames:
    #  identifier: initiatingProcessSHA256 # sha256, sha1, initiatingProcessSHA1, initiatingProcessSHA256

Impacted Assets

When deploying raw, the custom field impactedAssets is required for the asset mapping in the resulting alerts.

Note

The default value is currently deviceId but it might not always work depending on your KQL. As for the Sigma rules, if you make the use of | project for instance, make sure to output DeviceId.

Impacted Asset Type Identifier (Allowed Values)
Device deviceId, deviceName
Mailbox accountUpn, initiatingProcessAccountUpn
User targetAccountUpn, accountObjectId, accountSid, accountUpn, initiatingProcessAccountObjectId, initiatingProcessAccountSid, initiatingProcessAccountUpn
custom:
    # ...
    impactedAssets:
    - impactedAssetType: Device
        identifier: deviceId #deviceId, deviceName
    - impactedAssetType: Mailbox
        identifier: initiatingProcessAccountUpn #accountUpn, initiatingProcessAccountUpn
    - impactedAssetType: User
        identifier: initiatingProcessAccountUpn # targetAccountUpn, accountObjectId, accountSid, accountUpn, initiatingProcessAccountObjectId, initiatingProcessAccountSid, initiatingProcessAccountUpn
Warning

Failing to provide this field will result in non-working detection rules on the platform. We advise to introduce some validation check in your CI/CD process for the Microsoft XDR raw rules.