Skip to content

Latest commit

 

History

History
100 lines (71 loc) · 7.18 KB

README.md

File metadata and controls

100 lines (71 loc) · 7.18 KB

Content logo

CircleCI Language grade: Python

Demisto Platform - Content Repository

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.

Contributing

Contributions are welcome and appreciated. For instructions about adding/modifying content please see our Content Contribution Guide.

Playbooks

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.

Scripts

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

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.

Creating an Integration

Let's look at Demisto and get started on your first integration.

Follow the steps here to learn about the Demisto IDE

Code Conventions

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

Context and Outputs

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

Context Standards

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

Docker

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:

Docker Images

Reports

Demisto Platform support flexible reports written in JSON. All of our standard reports calculating various incident statistics and metrics are stored in this repo.

Release Notes

For information about content release notes conventions, refer to our release notes documentation.

Documentation Directory

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].