Please refer to descriptions provided within the atomic actions/workflows for additional guidance on usage.
-
SecureX Orchestrator
Generate AO API Token [link]
WARNING: EXPERIMENTAL USE ONLYSecureX Orchestrator (SXO) APIs are not generally available/exposed in production yet. However, if the ‘AO’ API scope were to be added to a SecureX API Client, this workflow demonstrates how to use such an API Client to generate and retrieve a JWT token that can be used to make API calls to SXO, assuming the API methods are known to the user. The methodology used in this workflow may be subject to change once this functionality is available in production.
Steps involved:
- Generate a new Access Token for Cisco Threat Response (CTR) using the SecureX API Client (with AO scope added) credentials defined in the Account Key for the ‘CTR Admin’ target. This returns the SecureX Auth Token.
- Use the SecureX Auth Token to make a call to CTR’s AO endpoint to generate the JWT
- Clean up response
- Output a secure string with the SXO JWT
Observations & Usage Advise:- A given SXO JWT is valid only for ~10 minutes and needs to be regenerated thereafter using the same methodology.
- For northbound access to the API, it is recommended to run this workflow on a schedule (every <10 min), preserve the SXO JWT in a central secret management system like HashiCorp Vault & have external services retrieve the token from the Vault prior to making API calls to SXO. There are atomic actions available for Vault on this GitHub repo.
- If you do not have access to the AO API docs, you may benefit from the Swagger JSONs available provided in this repo here that you may use with the Swagger HTTP Activity
Oversight (Error Handling Framework) [link]
Oversight is an unsupervised error handling framework for SecureX Orchestrator (SXO) workflows.Oversight monitors a set of workflows (that you define) and based on what type of error (that you define) may be seen, triggers an appropriate error handler workflow (that you define).
NOTE: This workflow relies on a SecureX API Client with the 'AO' API scope.
Steps to use:
- Import this workflow to your SXO Org. Ensure you have your
CTR Admin
target setup that this workflow uses to pass a valid SXO JWT to Oversight. - You may want to put this workflow on a schedule (default, daily 9 AM UTC) or trigger it via an external system based on your use-case or time criticality of the workflows you're monitoring.
- The atomic action creates a Global Variable table named
Oversight - Monitored Workflows
. Access this table viaVariables
>Global Variables
to add what Workflow IDs (last path segment available in the URL when you open a workflow) you'd like oversight to monitor, what error regular expression signatures/patterns you'd like to look for and what Workflow ID you'd like oversight to call when the error signature/pattern is seen. - Your handler workflow must have at least the following three input variables for oversight to pass error context into:
Message
(string): the exact error messageInstance Id
(string): link to the instance run where the error is seenActivity Name
(string): name of the activity in the instance where the error is seen
Breadcrumbs (Logging & Tracing Framework) [logging workflow] [tracing workflow]
Breadcrumbs lets you add checkpoints to your SecureX Orchestrator (SXO) workflows that you can then use to track progress in near real-time or retrospectively via external systems. This can be specially useful as a stack trace for error/exception handling.NOTE: Breadcrumbs relies on a SecureX API Client with the 'AO' API scope.
In this repository, there are two workflows related to Breadcrumbs:
-
Breadcrumbs - Logging Block [link]
Place this workflow strategically in multiple 'checkpoints' of your parent workflow and Breadcrumbs will store all progress between two consecutive logging blocks in a table data type namedAll My Breadcrumbs
.Steps to use:
-
Import the workflow to your SXO Org. Ensure you have the
CTR Admin
target in your Org setup that this workflow uses to pass a valid SXO JWT token to Breadcrumbs. -
This atomic action creates a Global Variable table named
All My Breadcrumbs
to log to. The table has the following columns:Alternate Instance ID
: A friendly name that you provide to make it easier for you to identify & retrieve data for your workflow instance. This name can also have run time variables.Instance ID
: The instance or 'run' identifier of the workflow.Activity ID
: An identifier for each activity or block in your workflow between two consecutive Breadcrumbs.Log
: The name of the activity with any custom log messsage. The custom log message can also have run time variables.State
: Activity Status (success/error)Timestamp
: Activity timestamp in YYYY-MM-DDThh:mm:ss.sssZ format
-
Drop this workflow (it should be visible under the 'workflows' tab in the left pane as
Breadcrumbs - Logging Block
) into your parent workflow wherever you deem appropriate. You're free to drop as many logging blocks as you'd like, however, each block you drop to your workflow adds ~5 seconds (may vary under heavy load) to your workflow execution time.💡 Pro Tip: A best practice is to place a logging block immediately after an activity that involves communicating with an external entity (like a third-party API or database). You can then use the logging block to capture progress or any errors that the third-party returns.
-
You'll notice three input variables: an
Instance ID
(required), anAlternate Instance ID
(optional) & aCustom Log Message
(optional).- Populate the
Instance ID
using the Variable Browser >Workflow
>Output
>Instance Id
. - A good naming practice for your
Alternate Instance ID
is<some text that identifies your workflow> - <workflow start time>
. You can dynamically populate the workflow start time using the Variable Browser >Workflow
>Output
>Start time
. - Whatever you define in the
Custom Log Message
is suffixed to the Activity Name & stored.
- Populate the
-
Run the workflow you've added Breadcrumbs to. You should be able to see new entries added to the table now.
-
-
Breadcrumbs - Trigger Trace [link]
A sample workflow that can be externally triggered via SXO's REST API to trace the breadcrumbs of another workflow from theAll My Breadcrumbs
table & output progress in near real-time or retrospectively.Steps to use:
-
Import the workflow to your SXO Org.
-
Supply an
Instance ID
or anAlternate Instance ID
as input to this workflow to search for corresponding Breadcrumbs. If you use theAlternate Instance ID
, you can also provide a fuzzy string to search with, i.e. you do not need to provide an exact match. -
The output of this workflow is a JSON string with Breadcrumbs corresponding to your search. If there are multiple matches, multiple objects are returned, like:
{ "Sample WF1 - 2021-09-06T08:17:22.928216678Z": [{ "activity_id": "01R5OZ5IQY9CN3x9onnjR7z80wQoYb7ZkPh", "alt_instance_id": "Sample WF1 - 2021-09-06T08:17:22.928216678Z", "instance_id": "01R5OZ5IPN8HS5RvvYIcSoQsFhwhxiXjpae", "log": "Split String", "state": "success", "timestamp": "2021-09-06T08:17:23.921234578Z" }], "Sample WF1 - 2021-09-09T09:10:10.233331678Z": [{ "activity_id": "01R5OZ5IQY9CN3x9onnjR7z80wQoYb7ZkPh", "alt_instance_id": "Sample WF1 - 2021-09-09T09:10:10.233331678Z", "instance_id": "01S5O344N8HS5RvvYIcSoQsFh244iXjreq", "log": "Split String", "state": "success", "timestamp": "2021-09-09T09:10:11.232115338Z" }] }
-
Usage Guidance:
-
Since logging blocks are added sequentially to your workflow, you may want to ensure that "Continue Execution on Failure" is checked on your critical activities for a logging block to be able to capture errors that may occur in activities preceeding it.
-
A logging block must exist at the same level as the activities it needs to log. For example: placing a logging block just after a conditional block does not automatically log all activities inside the conditional - it only logs the conditional's overall state; if you'd like to log activities inside a conditional branch, you need to place one or more logging blocks within that conditional branch.
-
For usage in parallel blocks, you must have an active logging block in one parallel branch only and 'silent' logging blocks in all other parallel branches within the parallel block. A 'silent' logging block is one that is placed with the "Skip Activity Execution" parameter checked. This prevents the silent block from logging the activities above it, but can still be seen by the subsequent (non-silent or active) logging block as the preceeding logging block.
-
The architecture that Breadcrumbs uses is for demonstration purposes. In production, you may want to use a database for more performant logging as opposed to using SXO Table Data Types. We tend to implement one of three methodologies for production projects:
Methodology Pros Cons Log to SXO tables alone - Quickest write executions for a small number of workflows
- Minimal operational overhead- Not scalable for concurrent reads/writes, i.e. multiple parent workflows logging breadcrumbs concurrently to a single SXO table. Log to SXO tables as cache, move to a DB for persistent logging on a schedule - Ideal for large scale workflows that require quick write execution
- Benefit from quick writes to SXO tables and performant reads from DB- Requires an external database
- Added overhead to maintain a separate workflow that syncs cache to databaseLog directly to a DB - Handle concurrent reads/writes with ease - Slowest execution, prolongs workflow run time (recommended for workflows that prioritize reliability over speed of execution)
- Requires an external database
-
String
Basic Auth Encode [link]
This atomic action takes a username & password and returns a secure string with the Base64 equivalent that can be readily passed to an HTTP Basic Authorization Header.
-
HashiCorp Vault
Create/Update Secret [link]
WARNING: This will overwrite all the secrets stored in the path specified.Pre-Requisite: Create an HTTP Target for your HashiCorp Vault instance and point this atomic to it.
Docs: https://www.vaultproject.io/api/secret/kv/kv-v2#create-update-secret
Renew Vault Token [link]
Pre-Requisite: Create an HTTP Target for your HashiCorp Vault instance and point this atomic to it.This atomic returns the same token you pass in, but the lease period for the given token will be extended. The ideal way to use this would be to use this atomic in a workflow, which would be run on a schedule. Ensure that the "Clean Up After Successful Execution" option is checked on the workflow to avoid exposure of sensitive/privileged information.
Docs: https://www.vaultproject.io/api-docs/auth/token#renew-a-token
Retrieve Secret [link]
No Targets need to be pre-defined for this atomic action. Instead, information is fed in as inputs.The atomic action expects the secret path to be of the form
engine/data/secret
, whereengine
refers to the highest level secret engine andsecret
refers to the secret stored in the engine. Other inputs are self-explanatory. Output is a Secure String variable calledToken
that is the token retrieved from Vault for a given key/identifier.
Contributors:
- Aman Sardana ([email protected])
- Anant Nambiar ([email protected])
Cisco CX Managed Services - Operate, July 2021