Skip to main content

Microsoft Defender for Endpoint

Microsoft Defender for Endpoint is an endpoint protection tool that detects malware, network-based attacks, and flags phishing sites in your network. You can bring host and security data from Microsoft Defender into Brinqa to help you detect and respond to security threats, and gain a comprehensive view of your attack surface to strengthen your cybersecurity posture.

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

Connection settings

When setting up a data integration, select Microsoft Defender for Endpoint 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 Endpoint with Brinqa:

  • API URL: The Microsoft Defender for Endpoint API URL. The default URL is https://api.securitycenter.microsoft.com.

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

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

  • Client secret: The client secret associated with the service principal. Required if you are not using certificate-based authentication.

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

  • Private key: The private key associated with the service principal certificate. Required if you are not using a client secret.

Authentication requirements

You must provide either a client secret or a private key. If you don’t provide either, the connector cannot authenticate. If you provide both values, the connector uses private key for authentication.

Register a Microsoft Azure application

You must create a new application for the Microsoft Defender for Endpoint connector to authenticate with Azure AD and access the Microsoft Defender for Endpoint APIs. 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 Defender for Endpoint application registration

  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 show below:

Microsoft Defender for Endpoint client and tenant ID

To obtain your client secret, 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 what is needed for authentication. Copy the Value field and save it in a secure location.

    microsft defender client secret value

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 API permissions > Add a permission > APIs my organization uses and select WindowsDefenderATP.

  2. Click Application permissions, grant the following permissions, and then click Add permissions:

    • Machine: Machine.Read.All

    • Security Recommendation: SecurityRecommendation.Read.All

    • Software: Software.Read.All

    • User: User.Read.All

    • Vulnerability: Vulnerability.Read.All

  3. Click Grant admin consent for default directory, and then click Yes in the confirmation dialog. Your API permissions should resemble the following:

    Microsoft Defender for Endpoint Permissions

note

For additional information about Azure AD permissions, see Microsoft Azure documentation.

Generate a private key and certificate

If you choose to authenticate using a private key, you must generate a private key and certificate, upload the certificate to Azure, and then enter the combined string into the Private key field in the integration configuration.

Use your organization's approved method to generate the private key and certificate. If no method is available, or for testing purposes, you can follow the steps below to create a self-signed certificate using OpenSSL:

  1. Open your terminal and generate a new private key:

    openssl genpkey -algorithm RSA -out private_key.pem
  2. Generate a certificate signing request (CSR). Enter the required information when prompted:

    openssl req -new -key private_key.pem -out csr.pem
  3. Generate a self-signed certificate:

    openssl x509 -req -in csr.pem -signkey private_key.pem -out certificate.pem
  4. In the Microsoft Azure Portal, navigate to your registered Azure application.

  5. On the left-hand side of the page, click Certificates & secrets, click the Certificates tab, and then click Upload certificate.

    Upload the certificate.pem file you created in step 3.

  6. Click Add.

  7. Combine private_key.pem and certificate.pem into a single string, and paste the result into the Private key field in the integration configuration. Use the following format:

    -----BEGIN PRIVATE KEY-----
    <contents of private_key.pem>
    -----END PRIVATE KEY-----
    -----BEGIN CERTIFICATE-----
    <contents of certificate.pem>
    -----END CERTIFICATE-----
note

Additional settings

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

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

  • Fail sync on error: Select this option to fail the sync if an error occurs while downloading or processing the export file. If this option is not selected, the connector logs the error but continues processing.

Types of data to retrieve

The Microsoft Defender for Endpoint connector can retrieve the following types of data from the Microsoft Defender API:

Table 1: Data retrieved from Microsoft Defender

Connector ObjectRequiredMaps to Data Model
Installed PackageNoInstalled Package
MachineYesHost
PackageNoPackage
VulnerabilityNoVulnerability
Vulnerability DefinitionNoVulnerability Definition
info

For detailed steps on how to view the data retrieved from Microsoft Defender for Endpoint 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.

Installed Package

Table 2: Installed Package attribute mappings

Source Field NameMaps to Attribute
computerDnsNamednsNames
machine.idtargets
namename
osPlatformos
rbacGroupIdLocal variable
rbacGroupNameLocal variable
software.idtype
statusstatus
uiduid
info

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.

Machine

Table 3: Machine attribute mappings

Source Field NameMaps to Attribute
aadDeviceIdaadDeviceId, name
agentVersionLocal variable
CATEGORIEScategories
cloudProvidercloudProvider
computerDnsNamehostnames, privateDnsNames, publicDnsNames
defenderAvStatusLocal variable
deviceValueLocal variable
exclusionReasonLocal variable
exposureLevelLocal variable
healthStatusstatus
iduid
ipAddressesipAddresses, privateIpAddresses, publicIpAddress
isAadJoinedLocal variable
isExcludedLocal variable
isPotentialDuplicationLocal variable
lastSeenlastSeen
macAddressesmacAddresses
machineTagstags, instanceId
managedByLocal variable
managedByStatusLocal variable
mergedIntoMachineIdLocal variable
onBoardingStatusLocal variable
osArchitecturedescription, os
osBuilddescription, os
osPlatformdescription, os
osProcessorLocal variable
osVersionos
rbacGroupIdLocal variable
rbacGroupNameLocal variable
resourceIdLocal variable
riskScoreLocal variable
subscriptionIdLocal variable
team_idLocal variable
team_nameLocal variable
uptimeLocal variable
info

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.

Package

Table 4: Package attribute mappings

Source Field NameMaps to Attribute
activeAlertLocal variable
categoriescategories
exposedMachinesLocal variable
iduid
impactScoreLocal variable
namename
publicExploitLocal variable
Statusstatus
vendorLocal variable
versionsLocal variable
info

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.

Vulnerability

Table 5: Vulnerability attribute mappings

Source Field NameMaps to Attribute
cveIdtype
deviceIdtargets, deviceId
deviceNamehostnames, deviceName
diskPathsdiskPaths
eventTimestampsourceLastModified, lastFixed
firstSeenTimestampfirstFound
iduid
lastSeenTimestamplastFound
rbacGroupNamerbacGroupName
recommendedSecurityUpdaterecommendedSecurityUpdate
recommendedSecurityUpdateIdrecommendedSecurityUpdateId
registryPathsregistryPaths
resultsresults
softwareNamesoftwareName
softwareVendorsoftwareVendor
softwareVersionsoftwareVersion
sourceCreatedDatesourceCreatedDate
statusstatus, statusCategory
vulnerabilitySeverityLevelseverity, sourceSeverity
info

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.

Vulnerability Definition

Table 6: Vulnerability Definition attribute mappings

Source Field NameMaps to Attribute
cvssV3cvssV3BaseScore
descriptiondescription, summary
exploitTypesLocal variable
exploitUrisexploits, references
exploitVerified, publicExploit, exploitInKitexploitability
idcveIds, cveRecords, uid
namecveIds, name
publishedOnpublishedDate
recommendation.isHasUnpatchableCvepatchAvailable
recommendations.getRelatedComponentaffected
recommendation.getRecommendationNamerecommendation
severityseverity, sourceSeverity
updatedOnsourceLastModified
info

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.

Data lifecycle management (DLM) strategy

The following table details the DLM strategy for the Microsoft Defender for Endpoint connector:

Table 7: Microsoft Defender for Endpoint DLM strategy

Connector ObjectInactivity ConditionPurge PolicySummary
MachineLAST_SEEN NOT IN LAST 7 Days30 days after inactivityUses the LAST_SEEN attribute to identify machines inactive for the last 7 days, and then purges the records after 30 days of inactivity.
VulnerabilityDEVICE_LAST_SEEN NOT IN LAST 7 Days OR LAST_CAPTURED NOT IN LAST 1 Day30 days after inactivityUses the DEVICE_LAST_SEEN attribute to identify vulnerabilities inactive for the last 7 days or the LAST_CAPTURED attribute for vulnerabilities inactive in the last day, and then purges the records after 30 days of inactivity.

Operation options

The Microsoft Defender for Endpoint connector supports the following operation options. See connector operation options for information about how to apply them.

Click the tabs below to view the supported operation options per connector object.

Table 8: Installed Package operation options

Connector ObjectOptionAll Possible ValuesDescriptionExample
PackageidAny installed package IDRetrieve installed packages with the specified ID.Key: id Value: microsoft-_-edge. This key and value combination only retrieves installed packages with the microsoft-_-edge ID.
nameAny installed package nameRetrieve installed packages with the specified name.Key: name Value: edge. This key and value combination only retrieves installed packages with the edge name.
vendorAny installed package vendorRetrieve installed packages with the specified vendor name.Key: vendor Value: microsoft. This key and value combination only retrieves installed packages with the microsoft vendor name.
note

The option keys and values are case-sensitive as they are shown in this documentation.

Synchronization types

When using the Microsoft Defender for Endpoint connector, it's important to understand the different sync interval types available:

  1. Beginning of Time (BoT)

    • BoT syncs comprehensively pull all available data from your Microsoft Defender for Endpoint environment, as specified by your integration configuration. You should use a BoT sync for initial setups or complete data refreshes.
  2. Delta

    • Delta syncs retrieve only the data that has changed over the last 14 days since your last sync. You should use delta syncs after running an initial BoT sync for regular updates, capturing new, resolved, or updated data without reprocessing all historical data.

APIs

The Microsoft defender connector uses the Microsoft Defender for Endpoint API. Specifically, it uses the following endpoints:

Table 13: Microsoft Defender for Endpoint API Endpoints

Connector ObjectAPI Endpoints
Installed PackageGET /api/software/{softwareId}/distributions
GET /api/Software/{softwareId}/machineReferences
MachineGET /api/machines
PackageGET /api/software/{softwareId}/distributions
VulnerabilityGET /api/machines/SoftwareVulnerabilityChangesByMachine
GET /api/machines/SoftwareVulnerabilitiesExport
Vulnerability DefinitionGET /api/recommendations
GET /api/recommendationsId/vulnerabilities
GET /api/vulnerabilities

Changelog

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

Table 14: Microsoft Defender for Endpoint connector changelog

note

This connector is part of a bundled release with other connectors from the same vendor. If a version shows "No change", it means that the connector version was updated for consistency as part of the bundle, but no functional changes were made to this specific connector. You can update to or skip this version without affecting your existing configuration.

VersionDescriptionDate Published
3.4.23- Added a DEVICE_LAST_SEEN attribute to the Vulnerability object.
- Updated the data lifecycle management strategy for the Vulnerability object to use the DEVICE_LAST_SEEN attribute.
October 23rd, 2025
3.4.22No change.October 16th, 2025
3.4.21Reverted the changes implemented in 3.4.20, removing the package ID attachment to the TYPE attribute in the Vulnerability object. If you previously upgraded to 3.4.20 and purged data as recommended, you may need to purge again before upgrading to this version.October 15th, 2025
3.4.20Fixed an issue where the incorrect recommendations were populating for the Vulnerability Definition object. As a result, the RECOMMENDATION_ID attribute was added to the Vulnerability Definition object. This will impact how UID's are generated for vulnerability definitions. Therefore, it is strongly recommended to purge existing data associated with this connector before updating to v3.4.20.September 17th, 2025
3.4.19No change.August 5th, 2025
3.4.18Fixed an issue where the connector sync was marked as successful despite the Vulnerability object sync encountering java.io.EOFException errors. As a result, a new additional setting has been added to provide more control over sync behavior: Fail sync on errorAugust 4th, 2025
3.4.17Added the following attributes to the Vulnerability object:
  • DEVICE_ID
  • DEVICE_NAME
  • DISK_PATHS
  • RBAC_GROUP_NAME
  • RECOMMENDED_SECURITY_UPDATE
  • RECOMMENDED_SECURITY_UPDATE_ID
  • REGISTRY_PATHS
  • SOFTWARE_NAME
  • SOFTWARE_VENDOR
  • SOFTWARE_VERSION
August 1st, 2025
3.4.16Fixed an issue where Vulnerability Definition names were not generated correctly. The connector now uses the Vulnerability Definition NAME attribute when available, and falls back to the CVE_ID attribute if the name is not available.June 11th, 2025
3.4.15Fixed an issue where the Machine object sync was failing with a NullPointerException error.May 27th, 2025
3.4.14No change.May 21st, 2025
3.4.13No change.May 20th, 2025
3.4.12No change.April 22nd, 2025
3.4.11- Fixed an issue where the connector was not retrieving complete data during delta syncs for the Host and Vulnerability objects.
- Fixed an issue where the Vulnerability Definition name was missing. The connector now uses the vulnerability ID if the name is not provided by the API.
- Renamed the PATCH_AVAILABLE attribute to PATCHABLE on the Vulnerability Definition object.
April 7th, 2025
3.4.10The Client secret and Private key connection settings are now optional. If both are provided, the connector prioritizes the Private key for authentication.April 1st, 2025
3.4.9Added support for a new optional authentication method using a private key and certificate. For additional information, see Microsoft documentation.March 26th, 2025
3.4.8No change.February 12th, 2025
3.4.7No change.January 28th, 2025
3.4.5Added support for CVSS calculations to the Vulnerability Definition object. As a result, the following attributes have been added to Vulnerability Definition:
  • CVSS_V2_AC
  • CVSS_V2_AI
  • CVSS_V2_AU
  • CVSS_V2_AV
  • CVSS_V2_BASE_SCORE
  • CVSS_V2_CI
  • CVSS_V2_E
  • CVSS_V2_II
  • CVSS_V2_RC
  • CVSS_V2_RL
  • CVSS_V2_TEMPORAL_SCORE
  • CVSS_V2_VECTOR
  • CVSS_V3_AC
  • CVSS_V3_AI
  • CVSS_V3_AV
  • CVSS_V3_BASE_SCORE
  • CVSS_V3_CI
  • CVSS_V3_E
  • CVSS_V3_II
  • CVSS_V3_PR
  • CVSS_V3_RC
  • CVSS_V3_RL
  • CVSS_V3_UI
  • CVSS_V3_VECTOR
December 19th, 2024
3.4.4No change.December 6th, 2024
3.4.3No change.November 28th, 2024
3.4.2No change.October 7th, 2024
3.4.1Added support for Data lifecycle management to the Machine and Vulnerability objects.September 27th, 2024
3.4.0No change.September 17th, 2024
3.3.10Code cleanup and general maintenance.September 4th, 2024
3.3.9No change.August 27th, 2024
3.3.8Removed the WEAKNESSES attribute from the Package object.July 24th, 2024
3.3.7No change.July 24th, 2024
3.3.6Changed the WEAKNESS attribute type on the Package object from integer to string.July 8th, 2024
3.3.5- Added three new operation options for the Vulnerability object: rbacGroupId, severity, and status.
- Changed the SOURCE_RISK_SCORE attribute on the Machine object to SOURCE_RISK_RATING.
May 20th, 2024
3.3.4Code cleanup and general maintenance.May 20th, 2024
3.3.3No change.May 20th, 2024
3.3.2No change.May 9th, 2024
3.3.1The connector now retrieves the Installed Package and Package objects from Microsoft.May 3rd, 2024
3.3.0No change.April 30th, 2024
3.2.2Mapped Affected Software in a CVE to the AFFECTED attribute on the Vulnerability Definition object.April 26th, 2024
3.2.1Code cleanup and general maintenance.April 19th, 2024
3.2.0Code cleanup and general maintenance.April 4th, 2024
3.1.18Code cleanup and general maintenance.April 4th, 2024
3.1.17Added the following attributes to the Machine object:
  • MERGED_INFO_MACHINE_ID
  • POTENTIAL_DUPLICATION
  • SOURCE_STATUS
March 24th, 2024
3.1.16No change.March 14th, 2024
3.1.15Fixed an issue where the EXPLOITABILITY attribute in all Vulnerability Definition records was incorrectly set to 'Actively used'.February 11th, 2024
3.1.14Set the INSTANCE_ID attribute in the Machine object if the source specifies a value using the instanceId tag.February 2nd, 2024
3.1.13Made Vulnerability and Vulnerability Definition objects optional in data integration.January 26th, 2024
3.1.12No change.January 24th, 2024
3.1.11No change.October 11th, 2023
3.1.9Added a delay in deleting temporary storage to avoid syncing issues.July 20th, 2023
3.1.8The connector now uses updatedOn instead of publishedOn to fetch updates for the Vulnerability Definition object.July 19th, 2023
3.1.7- Enhanced to make concurrent attempts to retrieve recommendations for vulnerabilities. However, in the event of failure, it proceeds without this data.
- Increased the default setting for Maximum Retries to 10.
May 18th, 2023
3.1.6- Excluded 00000000-0000-0000-0000-000000000000 as a valid Azure Active Directory device ID.
- Updated dependencies.
May 9th, 2023
3.1.5- Fixed a null pointer exception when there's no filter provided.
- Fixed a null pointer exception when the Machine object is synced from the beginning of time.
May 8th, 2023
3.1.4Added filtering capability to the Machine and Vulnerability Definition objects.April 3rd, 2023
3.1.3Code cleanup and general maintenance.February 22nd, 2023
3.1.2Made the value of the HOSTNAME attribute consistent.February 14th, 2023
3.1.1Tried to generate a name for the Machine object based on its DNS name, IP addresses, or Azure Active Directory device ID.February 9th, 2023
3.1.0Ignored exceptions when downloading export files.February 8th, 2023
3.0.3Initial Integration+ release.February 7th, 2023