Overview
Sensitive Data Scanner in the Cloud scans telemetry data, such as your application logs, APM events, RUM events, and events from Event Management. The data that can be scanned and redacted are:
- Logs: All structured and unstructured log content, including log message and attribute values
- APM: Span attribute values only
- RUM: Event attribute values only
- Events: Event attribute values only
For each scanning rule, one of the following actions can be applied to matched sensitive data:
- Redact: Replace the entire matched data with a single token that you choose, such as [sensitive_data].
- Partially redact: Replace a specific portion of all matching values.
- Hash: Replace the entire matched data with a non-reversible unique identifier.
- Mask (available for logs only): Obfuscate all matching values. Users with the Data Scanner Unmaskpermission can de-obfuscate (unmask) and view this data in Datadog. See Mask action for more information.
You submit logs and events to the Datadog backend, so the data leaves your environment before it gets redacted. The logs and events are scanned and redacted in the Datadog backend during processing, so sensitive data is redacted before events are indexed and shown in the Datadog UI.
If you don’t want data to leave your environment before it gets redacted, use Observability Pipelines and the Sensitive Data Scanner processor to scan and redact sensitive data. See Set Up Pipelines for information on how to set up a pipeline and its components.
To use Sensitive Data Scanner in the Cloud, set up a scanning group to define what data to scan and then add scanning rules to determine what sensitive information to match within the data.
This document goes through the following:
Setup
Permissions
By default, users with the Datadog Admin role have access to view and set up scanning rules. To allow other users access, grant the data_scanner_read or data_scanner_write permissions under Compliance to a custom role. See Access Control for details on how to set up roles and permissions.
If a scanning rule uses the mask action (only available for logs) for matched sensitive data, users with the data_scanner_unmask permission can de-obfuscate and view the data in Datadog. Note: Datadog does not recommend using the mask action for credentials, unless you have a plan to respond to and rotate all leaked credentials. See Mask action for more information.
Add a scanning group
A scanning group determines what data to scan. It consists of a query filter, a set of buttons to enable scanning for logs, APM, RUM, and events, and the option to set sampling rates between 10% to 99% for each product. See the Log Search Syntax documentation to learn more about query filters.
For Terraform, see the Datadog Sensitive Data Scanner group resource.
To set up a scanning group, perform the following steps:
- Navigate to the Sensitive Data Scanner settings page.
- Click Add scanning group. Alternatively, click the Add dropdown menu on the top right corner of the page and select Add Scanning Group.
- Enter a query filter for the data you want to scan. At the top, click APM Spans to preview the filtered spans. Click Logs to see the filtered logs.
- Enter a name and description for the group.
- Click the option buttons to enable Sensitive Data Scanner for the products you want (for example, logs, APM spans, RUM events, and Datadog events).
- Optionally set a sampling rate of 10-99% for the products you want. When you add scanning rules to a group that has sampling enabled, you will not be able to select actions that obfuscate the data it scans. To obfuscate matches, you must choose to scan all data matching your group query filter.
- Click Create.
By default, a newly-created scanning group is disabled. To enable a scanning group, click the corresponding toggle on the right side.
Add scanning rules
A scanning rule determines what sensitive information to match within the data defined by a scanning group. You can add predefined scanning rules from Datadog’s Scanning Rule Library or create your own rules using regex patterns. The data is scanned at ingestion time during processing. For logs, this means the scan is done before indexing and other routing decisions.
For Terraform, see the Datadog Sensitive Data Scanner rule resource.
To add scanning rules, perform the following steps:
- Navigate to the Sensitive Data Scanner settings page.
- Click the scanning group where you want to add the scanning rules.
- Click Add Scanning Rule. Alternatively, click the Add dropdown menu on the top right corner of the page and select Add Scanning Rule.
- Select whether you want to add a library rule or create a custom scanning rule.
The Scanning Rule Library contains predefined rules for detecting common patterns such as email addresses, credit card numbers, API keys, authorization tokens, and more.
- Select a scanning group if you did not create this rule within a scanning group.
- In the Priority dropdown menu, select the priority level for the rule based on your business needs.
- In the Add Library Rules section, select the library rules you want to use.
- In the Action on Match section, select if you want to scan the Entire Event or Specific Attributes.- If you are scanning the entire event, you can optionally exclude specific attributes from getting scanned.
- If you are scanning specific attributes, specify which attributes you want to scan.
 
- For Define actions on match, select the action you want to take for the matched information. Note: Redaction, partial redaction, and hashing are all irreversible actions.- Redact: Replaces all matching values with the text you specify in the Replacement text field.
- Partially Redact: Replaces a specified portion of all matched data. In the Redact section, specify the number of characters you want to redact and which part of the matched data to redact.
- Hash: Replaces all matched data with a unique identifier. The UTF-8 bytes of the match is hashed with the 64-bit fingerprint of FarmHash.
- Mask (available for logs only): Obfuscates all matching values. Users with the Data Scanner Unmaskpermission can de-obfuscate (unmask) and view this data. See Mask action for more information.
 
- (Optional) Add tags you want to associate with events where the values match the specified regex pattern.- Datadog recommends using sensitive_dataandsensitive_data_categorytags. These tags can then be used in searches, dashboards, and monitors.
- See Control access to logs with sensitive data for information on how to use tags to determine who can access logs containing sensitive information.
 
- Click Add Rules.
Add custom keywords
The recommended keywords are used by default when library rules are added. After adding library rules, you can edit each rule separately and add keywords to or remove keywords from the keyword dictionary.
- Navigate to the Sensitive Data Scanner settings page.
- Click the scanning group with the rule you want to edit.
- Hover over the rule, and then click the pencil icon.
- In the Match Conditions section, click Custom Keywords.- To add keywords, enter a keyword and click the plus icon to add the keyword to the list.
- To remove keywords, click the X next to the keyword you want to remove.
- You can also require that these keywords be within a specified number of characters of a match. By default, keywords must be within 30 characters before a matched value.
- Note: You cannot have more than 20 keywords for a rule.
 
- In the Type or paste event data to test the rule section, add event data to evaluate your rule and add keywords to refine match conditions.
- Click Update.
You can create custom scanning rules using regex patterns to scan for sensitive data.
- Select a scanning group if you did not create this rule within a scanning group.
- Enter a name for the rule.
- In the Priority dropdown menu, select the priority level for the rule based on your business needs.
- (Optional) Enter a description for the rule.
- In the Match conditions section, specify the regex pattern to use for matching against events in the Define the regex field. Enter sample data in the Add sample data field to verify that your regex pattern is valid.
 Sensitive Data Scanner supports Perl Compatible Regular Expressions (PCRE), but the following patterns are not supported:- Backreferences and capturing sub-expressions (lookarounds)
- Arbitrary zero-width assertions
- Subroutine references and recursive patterns
- Conditional patterns
- Backtracking control verbs
- The \C“single-byte” directive (which breaks UTF-8 sequences)
- The \Rnewline match
- The \Kstart of match reset directive
- Callouts and embedded code
- Atomic grouping and possessive quantifiers
 
- For Check for keywords near regex pattern, add keywords to refine detection accuracy when matching regex conditions. For example, if you are scanning for a sixteen-digit Visa credit card number, you can add keywords like visa,credit, andcard.- To add keywords, enter a keyword and click the plus icon to add the keyword to the list.
- To remove keywords, click the X next to the keyword you want to remove.
- You can also require that these keywords be within a specified number of characters of a match. By default, keywords must be within 30 characters before a matched value.
Note: You cannot have more than 20 keywords for a rule.
 
- In the Type or paste event data to test the rule section, add event data to evaluate your rule and add keywords to refine match conditions.
- In the Action on Match section, select if you want to scan the Entire Event or Specific Attributes.- If you are scanning the entire event, you can optionally exclude specific attributes from getting scanned.
- If you are scanning specific attributes, specify which attributes you want to scan.
 
- For Define actions on match, select the action you want to take for the matched information. Note: Redaction, partial redaction, and hashing are all irreversible actions.- Redact: Replaces all matching values with the text you specify in the Replacement text field.
- Partially Redact: Replaces a specified portion of all matched data. In the Redact section, specify the number of characters you want to redact and which part of the matched data to redact.
- Hash: Replaces all matched data with a unique identifier. The UTF-8 bytes of the match is hashed with the 64-bit fingerprint of FarmHash.
- Mask (available for logs only): Obfuscates all matching values. Users with the Data Scanner Unmaskpermission can de-obfuscate (unmask) and view this data. See Mask action for more information.
 
- (Optional) Add tags you want to associate with events where the values match the specified regex pattern.- Datadog recommends using sensitive_dataandsensitive_data_categorytags. These tags can then be used in searches, dashboards, and monitors.
- See Control access to logs with sensitive data for information on how to use tags to determine who can access logs containing sensitive information.
 
- Click Add Rule.
Notes:
- Any rules that you add or update affect only data coming into Datadog after the rule was defined.
- Sensitive Data Scanner does not affect any rules you define on the Datadog Agent directly.
- After rules are added, ensure that the toggles for your scanning groups are enabled to begin scanning.
- When you add rules to a scanning group with sampling enabled, you will not be able to select the redact, partially redact, or hash actions. For complete obfuscation, disable sampling in your scanning group settings.
See Investigate Sensitive Data Findings for details on triaging sensitive data using the Findings page.
Excluded namespaces
There are reserved keywords that the Datadog platform requires for functionality. If any of these words are in a log that is being scanned, the 30 characters after the matched word are ignored and not redacted. For example, what comes after the word date in a log is usually the event timestamp. If the timestamp is accidentally redacted, that would result in issues with processing the log and being able to query it later. Therefore, the behavior for excluded namespaces is to prevent unintentionally redacting important information for product functionality.
The excluded namespaces are:
- host
- hostname
- syslog.hostname
- service
- status
- env
- dd.trace_id
- trace_id
- trace id
- dd.span_id
- span_id
- span id
- @timestamp
- timestamp
- _timestamp
- Timestamp
- date
- published_date
- syslog.timestamp
- error.fingerprint
- x-datadog-parent-id
- metrics._dd.
- metrics.dd.
- metrics._dd1.
- metrics.otel.trace_id
- metrics.otlp.
- metrics._sampling_priority_v1
- metrics._sample_rate
- meta._dd.
- meta.api.endpoint.
- meta.dd.
- meta_struct.dd.
- meta_struct._dd.
- meta_struct.api.endpoint.
- meta_struct.appsec.
- meta_struct.threat_intel.results.
- meta.otel.trace_id
- meta.otel.library.
- meta.otlp.
- trace_id
- span_id
- start
- timestamp
- end
- duration
- parent_id
- type
- resource
- resource_hash
- ingest_size_in_bytes
- ingestion_reason
- error
- flags
- status
- chunk_id
- host
- host_id
- hostname
- env
- service
- operation_name
- name
- version
- meta._dd.error_tracking
- meta.error.fingerprint
- meta.issue
- application.id
- session.id
- session.initial_view.id
- session.last_view.id
- view.id
- action.id
- resource.id
- geo
- error.fingerprint
- error.binary_images.uuid
- issue
- _dd.trace_id
- _dd.span_id
- _dd.usage_attribution_tag_names
- _dd.error.unminified_frames
- _dd.error.threads
Edit scanning rules
To edit scanning rules:
- Navigate to the Sensitive Data Scanner settings page.
- Hover over the scanning rule you want to edit and click the Edit (pencil) icon.
- Make the changes you want for the rule. Depending on the type of rule you are editing, see Add library rules or Add custom rule for more information on each setup section.
- Click Update.
Control access to logs with sensitive data
To control who can access logs containing sensitive data, use tags added by the Sensitive Data Scanner to build queries with role-based access control (RBAC). You can restrict access to specific individuals or teams until the data ages out after the retention period. See How to Set Up RBAC for Logs for more information.
Mask action
The mask action is only available for logs.
When you set up or edit a scanner rule, there is an Action on Match section where you can set the rule to use the mask action for matched sensitive data. The mask action obfuscates the sensitive data, but users with the Data Scanner Unmask permission can de-obfuscate (unmask) and view the data in Datadog.
Notes:
- Unmasking can only be performed on indexed logs within Datadog.
- Masked data that is accessed programmatically, such as by using the API or Terraform, or within archives, always appears obfuscated and cannot be unmasked.
- Unmasking does not work on rehydrated logs.
- Datadog does not recommend using the mask action for credentials, unless you have a plan to respond to and rotate all leaked credentials.
To unmask sensitive data, navigate to the Summary page, click on a scanning rule, and then click on a log. If you have permission to see masked data, that data has an eye icon next to it. Click the eye icon to reveal the data. You can also use the Log Explorer to view your masked log data.
To redact sensitive data contained in tags, you must remap the tag to an attribute and then redact the attribute. Uncheck Preserve source attribute in the remapper processor so that the tag is not preserved during the remapping.
To remap the tag to an attribute:
- Navigate to your log pipeline.
- Click Add Processor.
- Select Remapper in the processor type dropdown menu.
- Name the processor.
- Select Tag key(s).
- Enter the tag key.
- Enter a name for the attribute the tag key is remapped to.
- Disable Preserve source attribute.
- Click Create.
To redact the attribute:
- Navigate to your scanning group.
- Click Add Scanning Rule.
- Check the library rules you want to use.
- Select Specific Attributes for Scan entire event or portion of it.
- Enter the name of the attribute you created earlier to specify that you want it scanned.
- Select the action you want when there’s a match.
- Optionally, add tags.
- Click Add Rules.
Disable Sensitive Data Scanner
To turn off Sensitive Data Scanner entirely, set the toggle to off for each Scanning Group so that they are disabled.
Further reading
Additional helpful documentation, links, and articles: