Skip to main content

Microsoft Defender for Cloud

Microsoft Defender for Cloud is a cloud environment solution that focuses on threat detection, assessments, and security management across your cloud environments. You can bring alert, alert definition, cloud resource, host, subscription, and security data from Microsoft Defender for Cloud into Brinqa to gain a comprehensive view of your cloud security landscape, thus enhancing your cybersecurity posture.

This document details the information you must provide for the connector to authenticate with Microsoft Defender for Cloud and how to obtain that information from Microsoft. See create a data integration for step-by-step instructions on setting up the integration.

Required connection settings

When setting up a data integration, select Microsoft Defender for Cloud from the Connector drop-down. If you cannot find the connector in the drop-down, make sure that you have installed it first. You must provide the following information to authenticate Microsoft Defender for Cloud with Brinqa:

  • API URL: The Microsoft Defender for Cloud API URL. The default URL is https://management.azure.com.

  • Login URL: The Microsoft Azure authentication URL. The default URL is https://login.microsoftonline.com.

  • Client ID and Client secret: The client ID and client secret associated with the service principal, which must have permissions to log in to the Microsoft Azure Active Directory (Active AD) and return data from the Azure REST API.

  • Tenant ID: The unique identifier for the Active AD tenant associated with the service principal.

Register a Microsoft Azure application

You must create a new application for the Microsoft Defender for Cloud connector to authenticate with Azure AD and access the Azure REST API. To register an application in your Azure AD tenant, follow these steps:

  1. Log in to your Microsoft Azure Portal as an administrator.

  2. Navigate to and click Microsoft Entra ID.

  3. On the left-hand side of the page, click App registrations, and then click New registration.

  4. Give your new application a name, select the supported account types, and provide an optional Redirect URI. If you do not have a redirect URI, you can leave the field as is.

    Microsoft azure new application page

  5. Click Register.

note

For additional details about registering an application in Azure AD and creating a service principal, see Microsoft Azure documentation.

Obtain Microsoft Azure credentials

After you have created your new Microsoft Azure application, your client and tenant ID display. Copy the Application (client) ID and Directory (tenant) ID as shown below:

Microsoft Defender for Cloud Client and Tenant IDs

To obtain your client secret and optional subscription ID, follow these steps:

  1. Click Certificates & secrets and then click New client secret.

  2. Provide a description, set an expiry date, and then click Add.

    The new client secret displays. You cannot view the client secret again. There is both a Value and Secret ID. The Value field is needed for authentication. Copy the Value field and save it to a secure location.

    Defender for Cloud new client secret

note

For additional details about obtaining your Microsoft Azure credentials, see Microsoft documentation.

Assign permissions

After you have created your new Microsoft Azure application and obtained the authentication credentials, you must assign the required permissions for the application to access your data. To do so, follow these steps:

  1. Navigate to the applicable Azure subscription.

  2. Click Access control (IAM), click Add, and then click Add role assignment from the drop-down.

    Defender for Cloud role assignment

  3. In the Job function roles tab, search for and select the Reader role.

    • The Reader role allows you to view all resources, but does not grant permission to modify them.
  4. Click Next.

  5. In the Members tab, click the User, group, or service principal option.

  6. Click Select members, search for and click the application you registered earlier, and then click Select.

  7. Navigate to the Review + assign tab and click Review + assign.

note

If you do not have permissions to assign roles, contact your Azure administrator. For additional information, see Microsoft documentation.

(Optional) Create a management group for multiple subscriptions

If you have multiple Azure subscriptions, you can organize them into a single management group to uniformly set access controls. To do so, follow these steps:

  1. Log in to your Microsoft Azure Portal as an administrator.

  2. Search for "Management groups" in the search box and click Management groups.

  3. Click Create, provide a management group ID and display name, and then click Submit.

  4. On the Management groups page, click the name of the new management group.

  5. Click Add subscription, select the Azure subscriptions you want to add to the management group, and then click Save.

  6. Click Access control (IAM), click Add, and then click Add role assignment from the drop-down.

  7. Search for and select the role you want to assign to the management group.

  8. Click Next.

  9. In the Members tab, click the User, group, or service principal option.

  10. Click Select members, search for and click the application you registered earlier, or any relevant members who require this role, and then click Select.

  11. Navigate to the Review + assign tab and click Review + assign.

note

If you do not have permissions to create management groups, contact your Azure administrator. For additional information, see Microsoft documentation.

Additional settings

The Microsoft Defender for Cloud connector contains additional options for specific configuration:

  • Maximum retries: The maximum number of times that the integration attempts to connect to the Azure REST API before giving up and reporting a failure. The default setting is 5.

  • Subscription ID: A comma-separated list of unique identifiers for your Microsoft Azure subscriptions, which represent billing and resource usage entities within Azure. If no subscription IDs are provided, the connector retrieves data from all subscriptions associated with the tenant. To obtain your subscription ID, follow these steps:

    1. Log in to your organization's Microsoft Azure Portal as an administrator.

    2. Search for "Subscriptions" in the search box at the top of the page and click Subscriptions.

      The subscription IDs for your corresponding applications display. If desired, copy these values into the Subscription ID field in the integration configuration.

      Azure Subscription IDs

      Only provide a Subscription ID if you want to retrieve resources from specific subscriptions. Leave this field blank to retrieve data from all subscriptions.

Types of data to retrieve

The Microsoft Defender for Cloud connector can retrieve the following types of data from the Azure REST API:

Table 1: Data retrieved from Azure REST API

Connector ObjectRequiredMaps to Data Model
AlertYesAlert
Alert DefinitionYesAlert Definition
Cloud ResourceYesCloud Resource
HostYesHost
Resource GroupNoNot mapped
SubscriptionYesCloud Resource
ViolationYesViolation
Violation DefinitionYesViolation Definition
VulnerabilityYesVulnerability
Vulnerability DefinitionYesVulnerability Definition
info

The Microsoft Defender for Cloud connector does not currently support operation options for the types of data it retrieves.

For detailed steps on how to view the data retrieved from Microsoft Defender for Cloud in the Brinqa Platform, see How to view your data.

Attribute mappings

Expand the sections below to view the mappings between the source and the Brinqa data model attributes.

Alert

Table 2: Alert attribute mappings

Source Field NameMaps to Attribute
actionTakenLocal variable
additionalDataLocal variable
associatedResourcetargets
canBeInvestigatedLocal variable
compromisedEntityLocal variable
confidenceReasonsLocal variable
descriptiontype
endTimesourceLastModified
instanceIdLocal variable
isIncidentLocal variable
nameLocal variable
processingTimeLocal variable
startTimesourceCreatedDate
statestatus, statusCategory
subscriptionIdtargets
sysIduid
titleLocal variable
workspaceArmIdLocal variable
Alert Definition

Table 3: Alert Definition attribute mappings

Source Field NameMaps to Attribute
actionTakenLocal variable
additionalDataLocal variable
canBeInvestigatedLocal variable
compromisedEntityLocal variable
confidenceReasonsLocal variable
descriptiondescription
instanceIdLocal variable
isIncidentLocal variable
nameLocal variable
processingTimeLocal variable
remediationremediation
reportedSeverityseverity, sourceSeverity
titleuid, name
vendorNameaffected
workspaceArmIdLocal variable
Cloud Resource

Table 4: Cloud Resource attribute mappings

Source Field NameMaps to Attribute
SYS_IDuid
RESOURCE_IDdescription, Local variable
SUBSCRIPTION_IDdescription, Local variable
RESOURCE_NAMEdescription, name
RESOURCE_TYPEcategories, Local variable
SKU_NAMELocal variable
SKU_CAPACITYLocal variable
SKU_FAMILYLocal variable
SKU_MODELLocal variable
SKU_SIZELocal variable
SKU_TIERLocal variable
KINDLocal variable
LOCATIONLocal variable
IDENTITY_PRINCIPAL_IDLocal variable
IDENTITY_TENANT_IDLocal variable
IDENTITY_TYPELocal variable
PLAN_NAMELocal variable
PLAN_PRODUCTLocal variable
PLAN_VERSIONLocal variable
CREATED_TIMEsourceCreatedDate
CHANGED_TIMEsourceLastModified
PROVISIONING_STATEstatus
TAGStags
Host

Table 5: Host attribute mappings

Source Field NameMaps to Attribute
CHANGED_TIMEsourceModifiedDate
CREATED_TIMEsourceCreatedDate
IDENTITY_PRINCIPAL_IDLocal variable
IDENTITY_TENANT_IDLocal variable
IDENTITY_TYPELocal variable
KINDLocal variable
LOCATIONLocal variable
PLAN_NAMELocal variable
PLAN_PRODUCTLocal variable
PLAN_PUBLISHERLocal variable
PLAN_VERSIONLocal variable
PROVISIONING_STATEstatus(normalized), sourceStatus
RESOURCE_IDdescription
RESOURCE_NAMEdescription, hostnames, name
RESOURCE_TYPEcategories
SKU_CAPACITYLocal variable
SKU_FAMILYLocal variable
SKU_MODELLocal variable
SKU_NAMELocal variable
SKU_SIZELocal variable
SKU_TIERLocal variable
SUBSCRIPTION_IDdescription
SYS_IDuid
TAGStags
Resource Group

Table 6: Resource Group attribute mappings

Source Field NameMaps to Attribute
iduid
locationlocation
namename
propertiesLocal variable
tagstags
typeLocal variable
Subscription

Table 7: Subscription attribute mappings

Source Field NameMaps to Attribute
ASSET_CATEGORY_CLOUD_RESOURCEcategories
DISPLAY_NAMEname
STATEstatus(normalized),sourceStatus
TAGStags
UIDuid
Violation

Table 8: Violation attribute mappings

Source Field NameMaps to Attribute
sysIduid
subscriptionIdLocal variable
metadataNameLocal variable
resourceIdtargets, Local variable
titlename
statusCodestatus
STATUS_CAUSELocal variable
STATUS_DESCRIPTIONLocal variable
ADDITIONAL_DATELocal variable
TARGETtargets
Violation Definition

Table 9: Violation Definition attribute mappings

Source Field NameMaps to Attribute
ADDITIONAL_DATALocal variable
ASSESSMENT_TYPEcategories
CATEGORIEScategories
DESCRIPTIONdescription
IMPLEMENTATION_EFFORTLocal variable
NAMEname
POLICY_IDLocal variable
PREVIEWLocal variable
REMEDIATIONremediation
SEVERITYseverity, sourceSeverity, severityScore
SYS_IDuid
THREATSLocal variable
TITLELocal variable
USER_IMPACTLocal variable
Vulnerability

Table 10: Vulnerability attribute mappings

Source Field NameMaps to Attribute
ADDITIONAL_DATALocal variable
IDuid
PATCHABLELocal variable
RESOURCE_GROUPLocal variable
RESOURCE_IDLocal variable
SOFTWARE_INSTALLED_VERSIONLocal variable
STATUSstatus(normalized), statusCategory, sourceStatus
STATUS_CAUSELocal variable
STATUS_DESCRIPTIONLocal variable
SUBSCRIPTION_IDLocal variable
TARGETStargets
TIME_GENERATEDfirstFound
UIDtype, uid
Vulnerability Definition

Table 11: Vulnerability Definition attribute mappings

Source Field NameMaps to Attribute
CATEGORIEScategories
CVE_IDScveIds, cveRecords
DESCRIPTIONdescription
DISPLAY_NAMEsummary
NAMEname
REMEDIATIONrecommendation
SEVERITYseverity
UIDtype, uid
SOURCE_SEVERITYseverity, sourceSeverity
SEVERITY_SCOREseverityScore
note

Local variable indicates that the field is processed within a specific context, such as a particular workflow or calculation. Unlike other attributes, local variables aren't mapped to the unified data models. They only exist on the source data model.

APIs

The Microsoft Defender for Cloud connector uses the Azure REST API. Specifically, it uses the following endpoints:

Table 12: Microsoft Defender for Cloud API Endpoints

Connector ObjectAPI Endpoints
AlertGET /subscriptions/{subscriptionID}/providers/Microsoft.Security/alerts
Alert DefinitionGET /subscriptions/subscriptionID/providers/Microsoft.Security/alerts
Cloud ResourceGET /subscriptions/{subscriptionID}/resources
HostGET /subscriptions/{subscriptionID}/resources
Resource GroupGET /subscriptions/{subscriptionID}/resourcegroups
SubscriptionGET /subscriptions/{subscriptionID} (Used when subscription IDs are provided)
GET /subscriptions (Used when no subscriptions IDs are provided to retrieve all subscriptions)
ViolationGET /subscriptions/{subscriptionID}/providers/Microsoft.Security/assessments
Violation DefinitionGET /providers/Microsoft.Security/assessmentMetadata
VulnerabilityGET /assessments
Vulnerability DefinitionGET /assessments

Changelog

The Microsoft Defender for Cloud connector has undergone the following changes:

Table 13: Microsoft Defender for Cloud connector changelog

VersionDescription
3.4.5No change.
3.4.4Code clean up and general maintenance.
3.4.3The connector now retrieves the Resource Group object from Microsoft.
3.4.2- Fixed an issue where asset names overlapped between different subscriptions. The connector now uses resource IDs to uniquely identify assets.
- Normalized UIDs to resolve consolidation issues between violations and vulnerabilities.
3.4.1No change.
3.4.0- Made the Subscription ID optional in the integration configuration. If no subscription IDs are provided, the connector retrieves all available subscriptions for the provided tenant. Before updating to version 3.4.0, ensure that if you do not specify any subscription IDs, the connector retrieves data from all subscriptions. This may result in more data being brought in than expected. Specify subscription IDs if you want to limit data retrieval to only specific subscriptions.
- The default status attribute value for the Cloud Resource and Host objects are set to "Active".
3.3.9Fixed an issue where the Microsoft Defender for Cloud connector threw a "NoClassDefFound" error when updating the data integration to version 3.3.8.
3.3.8No change.
3.3.4- Made the TARGETS attribute lowercase on the Violation and Vulnerability objects.
- Made the UID attribute lowercase on the Asset object.
3.1.7- Added more connector objects, such as Host, Vulnerability, and Vulnerability Definition.
- Fixed an issue where the connector was responding with a multi-value attribute when it should be a single attribute.
3.1.6Added the source status to the Machine object.
3.1.12- Mapped the Assessment object to the Violation data model.
- Mapped the Assessment Metadata object to the Violation Definition data model.
3.1.11Initial Integration+ release.