Skip to content

Latest commit

 

History

History
116 lines (87 loc) · 4.54 KB

File metadata and controls

116 lines (87 loc) · 4.54 KB

QRadar

Required versions and Content Packs

The QRadar connector works with QRadar 7.3.3 and newer versions. The following QRadar content extensions must be installed before using this connector:

Format for making STIX translation calls via the CLI

python main.py <translator_module> <query or result> <STIX identity object> <data>

Note the identity object is only used when converting from AQL to STIX, but due to positional arguments, an empty hash will need to be passed in when converting from STIX patterns to AQL.

Converting from STIX patterns to AQL queries

Returns an object representing the aql query and a parsing of the input stix pattern:

{'aql_query:' resulting_aql_query_string, 'stix_parsing': [{'attribute': <STIX attribute>, 'comparison_operator': <comparison operator>, 'value': <STIX value>}]}

This example input pattern:

python main.py translate "qradar" "query" '{}' "[url:value = 'www.example.com' and mac-addr:value = '00-00-5E-00-53-00']"

Returns the following AQL query:

SELECT <defined QRadar fields> FROM events WHERE (sourcemac='00-00-5E-00-53-00' OR destinationmac='00-00-5E-00-53-00') AND url='www.example.com'

AQL query construction: SELECT statement

The QRadar event columns that make up the SELECT portion of the AQL query are defined in aql_event_fields.json. A default selection is provided, but custom selections can be added to this file.

AQL query construction: WHERE clause

STIX to AQL field mapping is defined in events_from_stix_map.json and flows_from_stix_map.json
STIX attributes that map to multiple AQL fields will have those fields joined by ORs in the returned query.
Translated STIX attributes are inserted into the AQL query in the order they are defined in the mapping file.
When translating from STIX patterns to AQL queries, the following list of objects and properties can be used.

AQL Passthrough

In addition to translating STIX patterns into AQL, the QRadar connector can also take in a native AQL query using the {"language":"aql"} option. This will just return back the passed-in query, where it can then be passed to the query transmission call and onto the QRadar search API.

translate qradar query '{}' "select * from events" '{"language":"aql"}'

will return

{
    "queries": [
        "select * from events"
    ]
}

Converting from QRadar events and flows to STIX

QRadar data to STIX mapping is defined in to_stix_map.json

This example QRadar data:

python main.py translate "qradar" "results" '{"type": "identity", "id": "identity--3532c56d-ea72-48be-a2ad-1a53f4c9c6d3", "name": "QRadar", "identity_class": "system"}' '[{"starttime": 1524227777191, "protocolid": 255, "sourceip": "9.21.123.112", "logsourceid":126, "qid": 55500004, "sourceport": 0, "eventcount": 1, "magnitude": 4, "identityip": "0.0.0.0", "destinationip": "9.21.123.112", "destinationport": 0, "category": 10009, "username": null}]'

Will return the following STIX observable:

{
  "type": "bundle",
  "id": "bundle--994b685e-6c42-4e0c-b6c4-f3da97fb4cf4",
  "objects": [
    {
      "type": "identity",
      "id": "identity--3532c56d-ea72-48be-a2ad-1a53f4c9c6d3",
      "name": "QRadar",
      "identity_class": "system"
    },
    {
      "id": "observed-data--62392b84-66a7-4984-a49d-7872986e0c48",
      "type": "observed-data",
      "created_by_ref": "identity--3532c56d-ea72-48be-a2ad-1a53f4c9c6d3",
      "objects": {
        "0": {
          "type": "ipv4-addr",
          "value": "9.21.123.112"
        },
        "1": {
          "type": "ipv6-addr",
          "value": "9.21.123.112"
        },
        "2": {
          "type": "network-traffic",
          "src_ref": "1",
          "src_port": 0,
          "dst_ref": "0",
          "dst_port": 0,
          "protocols": ["tcp"]
        },
        "3": {
          "type": "x-qradar",
          "log_source_id": 126,
          "identity_ip": "0.0.0.0",
          "magnitude": 4,
          "qid": 55500004
        }
      },
      "number_observed": 1,
      "created": "2018-04-20T12:36:17.191Z",
      "modified": "2018-04-20T12:36:17.191Z",
      "first_observed": "2018-04-20T12:36:17.191Z",
      "last_observed": "2018-04-20T12:36:17.191Z"
    }
  ]
}