Skip to content

ciscomanagedservices/ciscolive24-xdr-automate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

BRKATO-1557: Automating Detection & Response Outcomes using Cisco XDR and Generative AI

About Cisco Live | Link to Session Presentation | Link to Session Recording

Session Demo Objective

Note

At Cisco Live 2023, we demonstrated how you could author an incident response workflow in the XDR Automate GUI and automatically trigger it with the detection & subsequent creation of an incident in XDR, leveraging Automation Rules. We used a Command & Control attack as an example to present investigation with Cisco Umbrella & remediation with Cisco Secure Endpoint. See 2023's session repository for more details.

We refer to these workflows as being rules-based because they only work for the use-cases that they are authored for and follow a pre-defined, prescriptive sequence of activities.

At Cisco Live 2024, we introduce a framework built with XDR Automate that enables AI-driven response workflows, powered by a Large Language Model and equipped with specialized tools, that can triage a large variety of incident types without pre-defined, prescriptive sequencing of activities.

This framework will allow you to:

  1. Benefit from the vast, inherent knowledge AI Large Language Models have of how to respond to security events, readily applied to XDR Incidents
  2. Bring or create your own XDR Automate 'tool' workflows to teach or empower AI to interface with a product or capability, perform analysis or collaborate with other AI agents & tools
  3. Control AI's behavior or change functionality using natural language in plain text (seriously, how much simpler could it get?)

Our Framework

The visualization below represents how the framework comes together:

graph TD
    CiscoSecure[Cisco Secure<br/>Umbrella, Secure Endpoint, Secure Cloud Analytics etc.] -->|Events| XDRIncident[XDR Incident]
    XDRIncident --> AutoRule[Automation Rule]
    AutoRule -->|Triggers| XdraiAgent[XDR AI Agent]

    SystemPrompt[System Prompt] -.->|Input| XdraiAgent[XDR AI Agent]
    ToolInputs[Tools] -.->|Input| XdraiAgent[XDR AI Agent]

    subgraph ToolWorkflows[Tool Workflows]
        reqApproval[Request Approval]
        secEndpointAPI[Secure Endpoint API]
        umbInvestigate[Umbrella Investigate]
        updateIncident[Update XDR Incident]
        sendWebexMsg[Send Webex Notification]
    end

    ToolWorkflows[Tool Workflows] --> ToolInputs

    AzureOpenAI[Azure OpenAI] <--> XdraiAgent[XDR AI Agent]
Loading

In this repository, you'll find the following workflows:

  1. XDR Incident Agent: Parent workflow that brings it all together. This workflow accepts XDR Incidents and works with the tools at it's disposal in an attempt to diagnose, investigate and remediate the incident.
    1. [Subworkflow] Convert Workflows to OpenAI Tools: This workflow automagically converts your XDR Automate workflows into 'tools' that the XDR Incident Agent can use.
  2. Tool Workflows (we provide the following as examples):
    1. Tool - Request Change Approval: creates an approval task in XDR for human intervention.
    2. Tool - Secure Endpoint API: a web service client to interact with the Secure Endpoint API.
    3. Tool - Umbrella Investigate API: a web service client to interact with the Umbrella Investigate API.
    4. Tool - Update XDR Incident: creates a worklog entry/note on an XDR incident.
    5. Tool - Send Webex Notification: sends a message to a Webex space.

Guidance on building tool workflows

  1. Descriptions: Your workflow, input & output variables must have descriptions. This is how the XDR Incident Agent interprets what each tool does, which directly influences what tool it selects to perform the task it needs to perform.
  2. Outputs: For consistency, have an output variable (like o_message_content in the example tools) per tool workflow, that you populate with the successful execution output (like the response payload for a tool that makes an API request) or with the error message in the event your tool workflow fails.
  3. Categorize: Put all your tool workflows into a category. You will then supply the name of this category as input to the Convert Workflows to OpenAI Tools workflow; this is how it knows how to find your tools.


Please note that workflow content in this repository will not be kept up to date with new code releases/patches. If you're a Cisco Live attendee, you may create an issue on this repository or reach out to us via email for queries and/or feedback.

Oh and, while you're here, you may want to check out some of our other content as well 🚀

Contributors:

  1. Aman Sardana (amasarda@cisco.com)
  2. Scott Dozier (scdozier@cisco.com)

Cisco CX Lifecycle Services & Automation, June 2024

About

Code repository for Cisco Live Session BRKATO-1557

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks