This repo contains content provided by Demisto to automate and orchestrate your Security Operations. Here we will share our ever-growing list of playbooks, automation scripts, report templates and other useful content.
We security folks love to tinker, keep enhancing and sharpening our toolset and we decided to open up everything and make it a collaborative process for the entire security community. We want to create useful knowledge and build flexible, customizable tools, sharing them with each other as we go along.
We invite you to use the playbooks and scripts, modify them to suit your needs and see what works for you, get involved in the community discussion and of course remember to give back and contribute so that others can enjoy and learn from your hard work and build upon it to enhance it even further.
Contributions are welcome and appreciated. For instructions about adding/modifying content please see our Content Contribution Guide.
The Demisto Platform includes a visual playbook editor - you can add and modify tasks, create control flow according to answers returned by your queries, and automate everything with your existing security tools, services and products. You can also export your work to a file in the COPS format, and import playbooks shared by your peers who have done the same.
We will be releasing more and more playbooks for interesting scenarios, so stay tuned. If you are working on an interesting playbook of your own, feel free to send us a Pull Request and let's build it together.
The spec for our open playbook format, COPS, can be found here.
These scripts written in Python or Javascript perform Security Operations tasks. The scripts are built to run inside the Demisto Platform - they can query or send commands to a long list of existing security products, and react based on the output.
You can take your logic and the way you want to work and write your own scripts, allowing for maximum flexibility. The services and products you use can be online Cloud-based or on-premises setups, and we have tools to support more complex topologies such as when the product's subnet is firewalled off.
Integrations written in Javascript or Python enable the Demisto Platform to orchestrate security and IT products. Each integration provides capabilities in the form of commands and each command usually reflects a product capability (API) and returns both a human readable and computer readable response.
Let's look at Demisto and get started on your first integration.
Follow the steps here to learn about the Demisto IDE
The Demisto Code Conventions will help you understand how we format our Integrations and some of the tips and tricks we have developed over the years.
Learn about the Demisto Code Conventions
The Demisto platform relies heavily on collecting data from various endpoints (integrations) and creating a "Context" for them. This allows customers to be able to use the data to perform various tasks they may need to accomplish.
Click here to learn about Context and Outputs
When we are working with data that is generic across all platforms, we format them according to our context standards. This helps integrations work interchangeably inside other playbooks.
Learn about our Context Standards here
We use docker to run python scripts and integrations in a controlled environment. You can configure an existing docker image from the Demisto Docker Hub Organization or create a new docker image to suite your needs. More information about how to use Docker is available here:
Demisto Platform support flexible reports written in JSON. All of our standard reports calculating various incident statistics and metrics are stored in this repo.
For information about content release notes conventions, refer to our release notes documentation.
Link | Description |
---|---|
Tutorial Video | A step-by-step introduction to creating an integration |
Getting Started | Environment setup and a brief explanation of the Demisto IDE |
Package directory | Explanation of Python integration / automation script package directory structure |
Code Conventions | Our Code Conventions |
Linting | How to run linting on Demisto integrations/scripts |
Unit Testing | Explanation of How to Perform Unit Testing on Integrations/Scripts |
Integration Parameter Types | Description of the various integration parameter types |
Context and Outputs | Brief overview of Context and Outputs |
Context Conventions | Conventions for the Demisto Standard Context |
Contributing | How to contribute to the Content Repo |
Creating Playbooks | How to create a Playbook |
DBot Score | How the DBot Score works |
Demisto Transform Language (DT) | Understanding Demisto Transform Language (DT) |
Docker | How to use Docker |
Fetching Incidents | How to Fetch Incidents |
Fetching Credentials | How to Fetch Credentials |
Integration Documentation | How to generate documentation for an integration |
YAML File | Explanation of the Demisto YAML structure |
Testing | The Demisto Content Repo Testing Methods |
CircleCI | How we test using CircleCI |
Mocks | Explanation of how to test using mocked data |
GenericPolling Playbook | Explanation of how and when to use the GenericPolling playbook |
Release Notes | Explanation of our content release notes conventions |
Debugging | Explanation of how best to debug Demisto integrations and scripts |
Long Running Containers | Explanation of using long running containers to run specific processes in an integration forever |
Test Playbook | Explanation of how to test your integration using a playbook |
Playbook Conventions | Conventions and standards for our playbooks |
Enjoy and feel free to reach out to us on the DFIR Community Slack channel, or at [email protected].