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 viaaz login
app
: Azure Registration App
When using the default authentication:
- Head to
portal.azure.com
and authenticate using MFA - 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 IDDROID_AZURE_CLIENT_ID
: Client ID of the registration appDROID_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.