Add indicators in bulk to Microsoft Sentinel threat intelligence from a CSV or JSON file

In this how-to guide, you'll add indicators from a CSV or JSON file into Microsoft Sentinel threat intelligence. A lot of threat intelligence sharing still happens across emails and other informal channels during an ongoing investigation. The ability to import indicators directly into Microsoft Sentinel threat intelligence allows you to quickly socialize emerging threats for your team and make them available to power other analytics such as producing security alerts, incidents, and automated responses.


This feature is currently in PREVIEW. See the Supplemental Terms of Use for Microsoft Azure Previews for additional legal terms that apply to Azure features that are in beta, preview, or otherwise not yet released into general availability.


You must have read and write permissions to the Microsoft Sentinel workspace to store your threat indicators.

Select an import template for your indicators

Add multiple indicators to your threat intelligence with a specially crafted CSV or JSON file. Download the file templates to get familiar with the fields and how they map to the data you have. Review the required fields for each template type to validate your data before importing.

  1. From the Azure portal, go to Microsoft Sentinel.

  2. Select the workspace you want to import threat indicators into.

  3. Go to Threat Intelligence under the Threat Management heading.

    Screenshot of the menu options to import indicators using a file menu.

  4. Select Import > Import using a file.

  5. Choose CSV or JSON from the File Format drop down menu.

    Screenshot of the menu flyout to upload a CSV or JSON file, choose a template to download, and specify a source highlighting the file format selection.

  6. Select the Download template link once you've chosen a bulk upload template.

  7. Consider grouping your indicators by source since each file upload requires one.

The templates provide all the fields you need to create a single valid indicator, including required fields and validation parameters. Replicate that structure to populate additional indicators in one file. For more information on the templates, see Understand the import templates.

Upload the indicator file

  1. Change the file name from the template default, but keep the file extension as .csv or .json. When you create a unique file name, it will be easier to monitor your imports from the Manage file imports pane.

  2. Drag your indicators file to the Upload a file section or browse for the file using the link.

  3. Enter a source for the indicators in the Source text box. This value will be stamped on all the indicators included in that file. You can view this property as the SourceSystem field. The source will also be displayed in the Manage file imports pane. Learn more about how to view indicator properties here: Work with threat indicators.

  4. Choose how you want Microsoft Sentinel to handle invalid indicator entries by selecting one of the radio buttons at the bottom of the Import using a file pane.

    • Import only the valid indicators and leave aside any invalid indicators from the file.
    • Don't import any indicators if a single indicator in the file is invalid.

    Screenshot of the menu flyout to upload a CSV or JSON file, choose a template to download, and specify a source highlighting the Import button.

  5. Select the Import button.

Manage file imports

Monitor your imports and view error reports for partially imported or failed imports.

  1. Select Import > Manage file imports.

    Screenshot of the menu option to manage file imports.

  2. Review the status of imported files and the number of invalid indicator entries.The valid/invalid indicator count is updated once the file is processed. Please wait for the import to complete to get the updated count of valid/invalid indicators.

    Screenshot of the manage file imports pane with example ingestion data. The columns show sorted by imported number with various sources.

  3. View and sort imports by selecting Source, indicator file Name, the number Imported, the Total number of indicators in each file, or the Created date.

  4. Select the preview of the error file or download the error file containing the errors about invalid indicators.

Microsoft Sentinel maintains the status of the file import for 30 days. The actual file and the associated error file are maintained in the system for 24 hours. After 24 hours the file and the error file are deleted, and the ingested indicators will continue to show in the Threat Intelligence menu.

Understand the import templates

Review each template to ensure your indicators are imported successfully. If this is your first import, be sure to reference the instructions in the template file and follow the supplemental guidance below.

CSV template structure

  1. Choose between the File indicators or All other indicator types option from the Indicator type drop down menu when you select CSV.

    The CSV template needs multiple columns to accommodate the file indicator type because file indicators can have multiple hash types like MD5, SHA256, and more. All other indicator types like IP addresses only require the observable type and the observable value.

  2. The column headings for the CSV All other indicator types template include fields such as threatTypes, single or multiple tags, confidence, and tlpLevel. TLP or Traffic Light Protocol is a sensitivity designation to help make decisions on threat intelligence sharing.

  3. Only the validFrom, observableType and observableValue fields are required.

  4. Delete the entire first row from the template to remove the comments before upload.

  5. Keep in mind the max file size for a CSV file import is 50MB.

Here's an example domain-name indicator using the CSV template.

Phishing,"demo, csv",MDTI article - Franken-Phish domainname,Entity appears in MDTI article Franken-phish,100,,2022-07-18T12:00:00.000Z,,white,5,domain-name,

JSON template structure

  1. There is only one JSON template for all indicator types. The JSON template is based on STIX 2.1 format.

  2. The pattern element supports indicator types of: file, ipv4-addr, ipv6-addr, domain-name, url, user-account, email-addr, and windows-registry-key types.

  3. Remove the template comments before upload.

  4. Close the last indicator in the array using the "}" without a comma.

  5. Keep in mind the max file size for a JSON file import is 250MB.

Here's an example ipv4-addr indicator using the JSON template.

      "type": "indicator",
      "id": "indicator--dbc48d87-b5e9-4380-85ae-e1184abf5ff4",
      "spec_version": "2.1",
      "pattern": "[ipv4-addr:value = '']",
      "pattern_type": "stix",
      "created": "2022-07-27T12:00:00.000Z",
      "modified": "2022-07-27T12:00:00.000Z",
      "valid_from": "2016-07-20T12:00:00.000Z",
      "name": "Sample IPv4 indicator",
      "description": "This indicator implements an observation expression.",
      "indicator_types": [
      "kill_chain_phases": [
            "kill_chain_name": "mandiant-attack-lifecycle-model",
            "phase_name": "establish-foothold"
      "labels": ["proxy","demo"],
      "confidence": "95",
      "lang": "",
      "external_references": [],
      "object_marking_refs": [],
      "granular_markings": [],

Next steps

This article has shown you how to manually bolster your threat intelligence by importing indicators gathered in flat files. Check out these links to learn how indicators power other analytics in Microsoft Sentinel.