A Coordinated and Automated Incident Response Workflow Leveraging Cisco Security.
When a security incident happens, time is your enemy. It's during this time between compromise and remediation that potentially allows the threat to spread, data to be exfiltrated, or other hosts to encounter the same source of infection. Incident responders typically will need to query multiple dashboards, various sources of threat information, and struggle to coordinate between all teams when responding to an incident.
This app puts time back on the side of the responder. It allows them to quickly identify confirmed threats, investigate them, contain them, and limit additional threats from impacting their organization. In addition, it puts all of the tools required during the incident response lifecycle in one interface and harnesses the power of Cisco's secure architecture.
This application will aid security operations teams and incident responders by quickly identifying compromised hosts and allowing them to be segmented to contain the malware or lateral movement. It also allows the responder to investigate the source of the infection using Cisco technologies and threat information and can limit future exposures to those, or similar threats. Finally, it centralized communication about the incident so it can be tracked and muliple teams can coordinate efforts.
Our solution will leverage the following Cisco technologies:
and third-party tools including:
This python project primarily uses the Cisco Security APIs to gather indications of compromise, information about the associated threats, and enforce policy. Underneath the hood it uses a Flask/Jinja2 framework, utilizing the Cisco UI Kit, for UX and TinyDB to store the results of API calls to minimize the number of calls and reduce latency of loading information. The incident response tool also feeds the incident report into both Webex Teams and into an ITSM ticketing system to track the incident through its lifecycle and coordinate response from multiple teams.
git clone https://github.com/CiscoSE/irflow.git
pip install -r requirements.txt
edit config.sample.yml with your API keys and credentials
rename config.sample.yml to config.yml
python ./app.py (web interface) or python ./headless.py (service)
A video demonstration of this project can be found at https://youtu.be/KwFILkVnbEo
The web interface relies on three databases that are populated with details from the API calls: threats_db.json, domains_db.json, and hosts_db.json. Running the headless script first will create and populate these databases. After initial creation, you can use the web interface and it will display the collected data. The headless script will continue to add new IOCs and associated details to the databases on an hourly basis when it is running or can be triggered on demand to gather new details.
The web interface runs on a localized instance on port 5555. After running app.py, you can access the web interface using http://localhost:5555.
Currently, the app requires AMP4E, Investigate, Threat Grid, and Umbrella at a minimum to operate. ISE is required for user details and threat response and Webex Teams and ServiceNow are required for the incident report functionality. Cognitive Intelligence, Firepower, Cisco Threat Response, and CMX are optional and can omitted with minimal changes to the code.
Features:
Threat Investigation - Lists the IOCs and details about impacted hosts. Clicking on the hostname reveals additional details about logged in users, host location, and site contact.
Threat Response - Allows you to initiate an Rapid Threat Response action against an identified threat. The host will be quarantined from ISE using the ANC feature.
Threat Research - Provides additional details from Threat Grid and Umbrella Investigate using the threat (SHA256) as a query term.
Incident Reports - Populated by the investigator, this form will be included with the creation of a new Webex Teams room and will trigger the creation of a service ticket in ServiceNow.
Settings (gear icon) - Add or update any of the fields from the config.yml file.
Search (magnifying glass icon) - Search the database for a MAC, IP or SHA256.
Provided under Cisco Sample Code License, for details see LICENSE
Our code of conduct is available here
See our contributing guidelines here
Code Exchange Community
Get help, share code, and collaborate with other developers in the Code Exchange community.View Community