From c14ae2c8d76f9625d06dd6776335719ed2a465af Mon Sep 17 00:00:00 2001 From: anuj-metron Date: Tue, 31 Dec 2024 15:01:42 +0530 Subject: [PATCH] Updated the Doppel Package with Additional Requirements --- Packs/Doppel/Integrations/Doppel/Doppel.py | 312 +++++- Packs/Doppel/Integrations/Doppel/Doppel.yml | 281 +++--- .../Doppel/Integrations/Doppel/Doppel_test.py | 12 +- Packs/Doppel/Integrations/Doppel/README.md | 17 +- ...classifier-Doppel_Incident_Classifier.json | 42 + .../classifier-Doppel_Incoming_Mapper.json | 423 ++++++++ .../classifier-Doppel_Outgoing_Mapper.json | 49 + .../incidentfield-Doppel_Alert_ID.json | 63 ++ .../incidentfield-Doppel_Audit_Logs.json | 136 +++ .../incidentfield-Doppel_Brand.json | 63 ++ .../incidentfield-Doppel_Created_At.json | 63 ++ .../incidentfield-Doppel_Entity.json | 63 ++ .../incidentfield-Doppel_Entity_Content.json | 173 ++++ .../incidentfield-Doppel_Entity_State.json | 68 ++ .../incidentfield-Doppel_Link.json | 63 ++ .../incidentfield-Doppel_Notes.json | 63 ++ .../incidentfield-Doppel_Platform.json | 63 ++ .../incidentfield-Doppel_Product.json | 72 ++ .../incidentfield-Doppel_Queue_State.json | 71 ++ .../incidentfield-Doppel_Severity.json | 63 ++ .../incidentfield-Doppel_Source.json | 63 ++ .../incidentfield-Doppel_Tags.json | 63 ++ .../incidentfield-Doppel_Uploaded_By.json | 63 ++ .../incidenttype-Doppel_Alert_Crypto.json | 38 + .../incidenttype-Doppel_Alert_Domains.json | 38 + .../incidenttype-Doppel_Alert_Ecommerce.json | 38 + .../incidenttype-Doppel_Alert_Email.json | 38 + ...incidenttype-Doppel_Alert_Mobile_Apps.json | 38 + .../incidenttype-Doppel_Alert_Paid_Ads.json | 38 + ...ncidenttype-Doppel_Alert_Social_Media.json | 38 + ...youtscontainer-Doppel_Incident_Layout.json | 902 ++++++++++++++++++ 31 files changed, 3343 insertions(+), 174 deletions(-) create mode 100644 Packs/Doppel/classifier/classifier-Doppel_Incident_Classifier.json create mode 100644 Packs/Doppel/classifier/classifier-Doppel_Incoming_Mapper.json create mode 100644 Packs/Doppel/classifier/classifier-Doppel_Outgoing_Mapper.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Alert_ID.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Audit_Logs.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Brand.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Created_At.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Entity.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_Content.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_State.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Link.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Notes.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Platform.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Product.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Queue_State.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Severity.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Source.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Tags.json create mode 100644 Packs/Doppel/incidentfield/incidentfield-Doppel_Uploaded_By.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Crypto.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Domains.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Ecommerce.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Email.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Mobile_Apps.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Paid_Ads.json create mode 100644 Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Social_Media.json create mode 100644 Packs/Doppel/layoutscontainer/layoutscontainer-Doppel_Incident_Layout.json diff --git a/Packs/Doppel/Integrations/Doppel/Doppel.py b/Packs/Doppel/Integrations/Doppel/Doppel.py index 93eaeeba52ee..db14bcf0e4c1 100644 --- a/Packs/Doppel/Integrations/Doppel/Doppel.py +++ b/Packs/Doppel/Integrations/Doppel/Doppel.py @@ -1,20 +1,33 @@ import demistomock as demisto # noqa: F401 from CommonServerPython import * # noqa: F401 +from CommonServerUserPython import * # noqa + import json +from datetime import datetime, timedelta """Doppel for Cortex XSOAR (aka Demisto) This integration contains features to mirror the alerts from Doppel to create incidents in XSOAR and the commands to perform different updates on the alerts """ -from CommonServerUserPython import * # noqa - import urllib3 from typing import Dict, Any # Disable insecure warnings urllib3.disable_warnings() +''' CONSTANTS ''' +XSOAR_DATE_FORMAT = '%Y-%m-%dT%H:%M:%SZ' +DOPPEL_API_DATE_FORMAT = '%Y-%m-%dT%H:%M:%S' +DOPPEL_PAYLOAD_DATE_FORMAT = '%Y-%m-%dT%H:%M:%S.%f' +MIRROR_DIRECTION = { + "None": None, + "Incoming": "In", + "Outgoing": "Out", + "Incoming And Outgoing": "Both", +} +DOPPEL_ALERT = 'Doppel Alert' +DOPPEL_INCIDENT = 'Doppel Incident' ''' CLIENT CLASS ''' @@ -67,6 +80,7 @@ def update_alert( entity_state: str, alert_id: Optional[str] = None, entity: Optional[str] = None, + comment: Optional[str] = None, ) -> Dict[str, Any]: """ Updates an existing alert using either the alert ID or the entity. @@ -85,7 +99,7 @@ def update_alert( api_name = "alert" api_url = f"{self._base_url}/{api_name}" params = {"id": alert_id} if alert_id else {"entity": entity} - payload = {"queue_state": queue_state, "entity_state": entity_state} + payload = {"queue_state": queue_state, "entity_state": entity_state, "comment" :comment} response_content = self._http_request( method="PUT", # Changed to PUT as per reference @@ -95,7 +109,7 @@ def update_alert( ) return response_content - def get_alerts(self, params: Dict[str, Any]) -> List[Dict[str, Any]]: + def get_alerts(self, params: Dict[str, Any]) -> Dict[str, Any]: """ Fetches multiple alerts based on query parameters. @@ -141,12 +155,85 @@ def create_abuse_alert(self, entity: str) -> Dict[str, Any]: ''' HELPER FUNCTIONS ''' -# TODO: ADD HERE ANY HELPER FUNCTION YOU MIGHT NEED (if any) +def _get_remote_updated_incident_data_with_entry(client: Client, doppel_alert_id: str, last_update_str: str): + # Truncate to microseconds since Python's datetime only supports up to 6 digits + last_update_str = last_update_str[:26] + "Z" + last_update = datetime.strptime(last_update_str, "%Y-%m-%dT%H:%M:%S.%fZ") + demisto.debug(f'Getting Remote Data for {doppel_alert_id} which was last updated on: {last_update}') + updated_doppel_alert = client.get_alert(id=doppel_alert_id, entity=None) + demisto.debug(f'Received alert data for {doppel_alert_id}') + audit_logs = updated_doppel_alert['audit_logs'] + demisto.debug(f'The alert contains {len(audit_logs)} audit logs') + + most_recent_audit_log = max(audit_logs, key=lambda audit_log: audit_log['timestamp']) + demisto.debug(f'Most recent audit log is {most_recent_audit_log}') + recent_audit_log_datetime_str = most_recent_audit_log['timestamp'] + recent_audit_log_datetime = datetime.strptime(recent_audit_log_datetime_str, DOPPEL_PAYLOAD_DATE_FORMAT) + demisto.debug(f'The event was modified recently on {recent_audit_log_datetime}') + if recent_audit_log_datetime > last_update: + updated_doppel_alert['id'] = doppel_alert_id + entries: list = [{ + "Type": EntryType.NOTE, + "Contents": most_recent_audit_log, + "ContentsFormat": EntryFormat.JSON, + }] + demisto.debug(f'Successfully returning the updated alert and entries: {updated_doppel_alert, entries}') + return updated_doppel_alert, entries + + return None, [] + +def _get_mirroring_fields(): + """ + Get tickets mirroring. + """ + mirror_direction: str = demisto.params().get('mirror_direction', None) + return { + "mirror_direction": MIRROR_DIRECTION.get(mirror_direction), + "mirror_instance": demisto.integrationInstance(), + "incident_type": "Doppel_Incident_Test", + } + +def _get_last_fetch_datetime(): + # Fetch the last run (time of the last fetch) + last_run = demisto.getLastRun() + last_fetch = last_run.get("last_fetch", None) + last_fetch_datetime: datetime = datetime.now() + if last_fetch and isinstance(last_fetch, float): + last_fetch_datetime = datetime.fromtimestamp(last_fetch) + demisto.debug(f"Alerts were fetch last on: {last_fetch_datetime}") + else: + # If no last run is found + historical_days: int = 1 + historical_days_str: str = demisto.params().get('historical_days', None) + if historical_days_str: + try: + historical_days = int(historical_days_str) + except ValueError: + demisto.error(f'{historical_days} is not an int value. We will use the default historical value as {historical_days} day') + demisto.info(f'Fetching alerts created in last {historical_days} days') + last_fetch_datetime = datetime.now() - timedelta(days=historical_days) + demisto.debug(f"This is the first time we are fetching the incidents. This time fetching it from: {last_fetch_datetime}") + + return last_fetch_datetime + +def _paginated_call_to_get_alerts(client, page, last_fetch_datetime): + # Set the query parameters + last_fetch_str: str = last_fetch_datetime.strftime(DOPPEL_API_DATE_FORMAT) + query_params = { + 'created_after': last_fetch_str, # Fetch alerts after the last_fetch, + 'sort_type': 'date_sourced', + 'sort_order': 'asc', + 'page': page, + } + get_alerts_response = client.get_alerts(params=query_params) + alerts = get_alerts_response.get('alerts', None) + return alerts + ''' COMMAND FUNCTIONS ''' -def test_module(client: Client) -> str: +def test_module(client: Client, args: Dict[str, Any]) -> str: """Tests API connectivity and authentication' Returning 'ok' indicates that the integration works like it is supposed to. @@ -160,21 +247,27 @@ def test_module(client: Client) -> str: :rtype: ``str`` """ - message: str = '' try: - # TODO: ADD HERE some code to test connectivity and authentication to your service. - # This should validate all the inputs given in the integration configuration panel, - # either manually or by using an API that uses them. - message = 'ok' + # Using the same dates so that we do not fetch any data for testing, + # but still get the response as 200 + current_datetime_str = datetime.now().strftime(DOPPEL_API_DATE_FORMAT) + query_params = { + 'created_before': current_datetime_str, + 'created_after': current_datetime_str + } + + # Call the client's `get_alerts` method to test the connection + results = client.get_alerts(params=query_params) + message: str = 'ok' + except DemistoException as e: - if 'Forbidden' in str(e) or 'Authorization' in str(e): # TODO: make sure you capture authentication errors + if 'Forbidden' in str(e) or 'Authorization' in str(e): message = 'Authorization Error: make sure API Key is correctly set' else: raise e return message - -def get_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: +def doppel_get_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: id: str = args.get('id', None) entity: str = args.get('entity', None) @@ -191,7 +284,7 @@ def get_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: outputs=result, ) -def update_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: +def doppel_update_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: """ Executes the update alert command. @@ -203,13 +296,14 @@ def update_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults entity = args.get('entity') queue_state = args.get('queue_state') entity_state = args.get('entity_state') + comment = args.get('comment') if alert_id and entity: raise ValueError("Only one of 'alert_id' or 'entity' can be specified.") if not queue_state or not entity_state: raise ValueError("Both 'queue_state' and 'entity_state' must be specified.") - result = client.update_alert(queue_state=queue_state, entity_state=entity_state, alert_id=alert_id, entity=entity) + result = client.update_alert(queue_state=queue_state, entity_state=entity_state, alert_id=alert_id, entity=entity , comment=comment) return CommandResults( outputs_prefix='Doppel.UpdatedAlert', @@ -217,7 +311,7 @@ def update_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults outputs=result, ) -def get_alerts_command(client: Client, args: Dict[str, Any]) -> CommandResults: +def doppel_get_alerts_command(client: Client, args: Dict[str, Any]) -> CommandResults: """ Command to fetch multiple alerts based on query parameters. @@ -248,17 +342,7 @@ def get_alerts_command(client: Client, args: Dict[str, Any]) -> CommandResults: if not results: raise ValueError("No alerts were found with the given parameters.") - # Prepare the readable JSON response - readable_output = json.dumps(results, indent=4) - - return CommandResults( - outputs_prefix="Doppel.GetAlerts", - outputs_key_field="id", - outputs=results, - readable_output=readable_output - ) - -def create_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: +def doppel_create_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: entity = args.get('entity') if not entity: raise ValueError("Entity must be specified to create an alert.") @@ -271,7 +355,7 @@ def create_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults outputs=result, ) -def create_abuse_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: +def doppel_create_abuse_alert_command(client: Client, args: Dict[str, Any]) -> CommandResults: entity = args.get('entity') if not entity: @@ -285,6 +369,136 @@ def create_abuse_alert_command(client: Client, args: Dict[str, Any]) -> CommandR outputs=result, ) +def fetch_incidents_command(client: Client, args: Dict[str, Any]) -> None: + """ + Fetch incidents from Doppel alerts, map fields to custom XSOAR fields, and create incidents. + This function fetches alerts directly from Doppel + """ + demisto.debug("Fetching alerts from Doppel.") + # Fetch the last run (time of the last fetch) + last_fetch_datetime: datetime = _get_last_fetch_datetime() + + # Fetch alerts + page: int = 0 + incidents = [] + while True: + alerts = _paginated_call_to_get_alerts(client, page, last_fetch_datetime) + if not alerts: + demisto.info("No new alerts fetched from Doppel. Exiting fetch_incidents.") + break + last_fetch = last_fetch_datetime.timestamp() + new_last_fetch = last_fetch # Initialize with the existing last fetch timestamp + for alert in alerts: + # Building the incident structure + created_at_str = alert.get("created_at") + created_at_datetime = datetime.strptime(created_at_str, DOPPEL_PAYLOAD_DATE_FORMAT) + new_last_fetch = created_at_datetime.timestamp() + if new_last_fetch > last_fetch: + alert.update(_get_mirroring_fields()) + incident = { + 'name': DOPPEL_INCIDENT, + 'type': DOPPEL_ALERT, + 'occurred': created_at_datetime.strftime(XSOAR_DATE_FORMAT), + 'dbotMirrorId': str(alert.get("id")), + 'rawJSON': json.dumps(alert), + } + incidents.append(incident) + # Update last run with the new_last_fetch value + demisto.setLastRun({"last_fetch": new_last_fetch}) + demisto.debug(f"Updated last_fetch to: {new_last_fetch}") + demisto.info(f'Fetched Doppel alerts from page {page} Successfully.') + page = page+1 + # Create incidents in XSOAR + if incidents and len(incidents) > 0: + try: + demisto.incidents(incidents) + demisto.info(f"Successfully created {len(incidents)} incidents in XSOAR.") + except Exception as e: + raise ValueError(f"Incident creation failed due to: {str(e)}") + else: + demisto.incidents([]) + demisto.info("No incidents to create. Exiting fetch_incidents_command.") + +def get_modified_remote_data_command(client: Client, args: Dict[str, Any]): + demisto.debug('Command get-modified-remote-data is not implemented') + raise NotImplementedError('The command "get-modified-remote-data" is not implemented, \ + as Doppel does provide the API to fetch updated alerts.') + +def get_remote_data_command(client: Client, args: Dict[str, Any]) -> GetRemoteDataResponse: + try: + demisto.debug(f'Calling the "get-remote-data" for {args["id"]}') + parsed_args = GetRemoteDataArgs(args) + remote_updated_incident_data, parsed_entries = _get_remote_updated_incident_data_with_entry(client, parsed_args.remote_incident_id, parsed_args.last_update) + if remote_updated_incident_data: + demisto.debug(f'Found updates in the alert with id: {args["id"]}') + return GetRemoteDataResponse(remote_updated_incident_data, parsed_entries) + else: + demisto.debug(f'Nothing new in the incident {parsed_args.remote_incident_id}') + return GetRemoteDataResponse(mirrored_object={}, entries=[{}]) + + except Exception as e: + demisto.error(f'Error while running get_remote_data_command: {e}') + if "Rate limit exceeded" in str(e): + return_error("API rate limit") + +def update_remote_system_command(client: Client, args: Dict[str, Any]) -> str: + + """update-remote-system command: pushes local changes to the remote system + + :type client: ``Client`` + :param client: XSOAR client to use + + :type args: ``Dict[str, Any]`` + :param args: + all command arguments, usually passed from ``demisto.args()``. + ``args['data']`` the data to send to the remote system + ``args['entries']`` the entries to send to the remote system + ``args['incidentChanged']`` boolean telling us if the local incident indeed changed or not + ``args['remoteId']`` the remote incident id + + :return: + ``str`` containing the remote incident id - really important if the incident is newly created remotely + + :rtype: ``str`` + """ + demisto.debug(f'Arguments for the update-remote-system is: {args}') + parsed_args = UpdateRemoteSystemArgs(args) + new_incident_id: str = parsed_args.remote_incident_id + # We will Update the Doppel Alert only if the XSOAR Incident is closed + if parsed_args.delta and parsed_args.delta.get('closeReason'): + demisto.debug(f'Sending incident with remote ID [{parsed_args.remote_incident_id}] to remote system') + if not parsed_args.remote_incident_id or parsed_args.incident_changed: + if parsed_args.remote_incident_id: + # First, get the incident as we need the version + old_incident = client.get_alert(id=parsed_args.remote_incident_id, entity=None) + for changed_key in parsed_args.delta.keys(): + old_incident[changed_key] = parsed_args.delta[changed_key] # type: ignore + parsed_args.data = old_incident + else: + parsed_args.data['createInvestigation'] = True + + # Update the queue_state value in the Doppel alert, if already not same + current_queue_state = parsed_args.data.get('queue_state') + target_queue_state = 'archived' + if current_queue_state != target_queue_state: + client.update_alert( + queue_state=target_queue_state, + entity_state=old_incident['entity_state'], # Keep the old entity_state + alert_id=new_incident_id + ) + else: + demisto.debug(f'Skipping updating remote incident fields [{parsed_args.remote_incident_id}] as it is ' + f'not new nor changed.') + else: + demisto.debug(f'The incident changed, but it is not closed. Hence will not update the Doppel alert at this time') + + return new_incident_id + +def get_mapping_fields_command(client: Client, args: Dict[str, Any]): + xdr_incident_type_scheme = SchemeTypeMapping(type_name=DOPPEL_ALERT) + xdr_incident_type_scheme.add_field(name='queue_state', description='Queue State of the Doppel Alert') + return GetMappingFieldsResponse(xdr_incident_type_scheme) + ''' MAIN FUNCTION ''' @@ -300,27 +514,35 @@ def main() -> None: # get the service API url base_url = urljoin(demisto.params()['url'], '/v1') - demisto.debug(f'Command being called is {demisto.command()}') + supported_commands = { + 'test-module': test_module, + 'fetch-incidents': fetch_incidents_command, + 'get-modified-remote-data:': get_modified_remote_data_command, + 'get-remote-data': get_remote_data_command, + 'update-remote-system': update_remote_system_command, + 'get-mapping-fields': get_mapping_fields_command, + + # Doppel Specific alerts + 'doppel-get-alert': doppel_get_alert_command, + 'doppel-update-alert': doppel_update_alert_command, + 'doppel-get-alerts': doppel_get_alerts_command, + 'doppel-create-alert': doppel_create_alert_command, + 'doppel-create-abuse-alert': doppel_create_abuse_alert_command, + } + + demisto.info(f'Command being called is {demisto.command()}') try: client = Client( base_url=base_url, api_key=api_key) current_command: str = demisto.command() - if current_command == 'test-module': - # This is the call made when pressing the integration Test button. - result = test_module(client) - return_results(result) - elif current_command == 'get-alert': - return_results(get_alert_command(client, demisto.args())) - elif current_command == 'update-alert': - return_results(update_alert_command(client, demisto.args())) - elif current_command == 'get-alerts': - return_results(get_alerts_command(client, demisto.args())) - elif current_command == 'create-alert': - return_results(create_alert_command(client, demisto.args())) - elif current_command == 'create-abuse-alert': - return_results(create_abuse_alert_command(client, demisto.args())) + if current_command in supported_commands: + demisto.info(f'Command run successful: {demisto.command()}') + return_results(supported_commands[current_command](client, demisto.args())) + else: + demisto.error(f'Command is not implemented: {demisto.command()}') + raise NotImplementedError(f'The {current_command} command is not supported') # Log exceptions and return errors except Exception as e: @@ -331,4 +553,4 @@ def main() -> None: if __name__ in ('__main__', '__builtin__', 'builtins'): - main() + main() \ No newline at end of file diff --git a/Packs/Doppel/Integrations/Doppel/Doppel.yml b/Packs/Doppel/Integrations/Doppel/Doppel.yml index dc7345c4fa10..fc504a858bcf 100644 --- a/Packs/Doppel/Integrations/Doppel/Doppel.yml +++ b/Packs/Doppel/Integrations/Doppel/Doppel.yml @@ -3,45 +3,160 @@ commonfields: id: Doppel version: -1 configuration: -- defaultvalue: https://.com/ - display: Doppel tenant URL +- additionalinfo: The Doppel server URL that will be used for calling the APIs + defaultvalue: https://.com/ + display: Doppel Tenant URL name: url required: true type: 0 -- displaypassword: API Key - additionalinfo: The API Key to use for connection with Doppel +- additionalinfo: The API Key to use for connection with Doppel + display: "" + displaypassword: API Key + hiddenusername: true name: credentials required: true - hiddenusername: true type: 9 -description: 'Doppel is a Modern Digital Risk Protection Solution, that detects the phishing and brand cyber attacks on the emerging channels. Doppel scans millions of channels online which includes, social media, domains, paid ads, dark web, emerging channels, etc. Doppel can identify the malicious content and cyber threats, and enables their customers to take down the digital risks proactively. The XSOAR pack for Doppel provides mirrors the alerts created by Doppel as XSOAR incidents. The pack also contains the commands to perform different operations on Doppel alerts.' +- display: Fetch incidents + name: isFetch + required: false + type: 8 +- additionalinfo: The interval specifies the cadence with which the Doppel alerts + be fetched + defaultvalue: "1" + display: Incidents Fetch Interval + name: incidentFetchInterval + required: true + type: 19 +- display: Incident type + name: incidentType + required: false + type: 13 +- additionalinfo: 'Choose the direction to mirror the incident: None (No mirroring), + Incoming (from Doppel to XSOAR), Outgoing (from XSOAR to Doppel), Incoming and + Outgoing (from/to Cortex and Doppel)' + defaultvalue: Incoming And Outgoing + display: Mirror Direction + name: mirror_direction + options: + - Incoming + - Outgoing + - Incoming And Outgoing + required: false + type: 15 +- additionalinfo: For the first time fetch (or on reset of "Last Run" timestamp), + fetch alerts created in the mentioned historical days + defaultvalue: "1" + display: Historical Days + name: historical_days + required: false + type: 0 +contentitemexportablefields: + contentitemfields: + definitionid: "" + fromServerVersion: "" + itemVersion: "" + packID: 82a5f67a-7fbd-4e4b-8c20-1677bbb400ac + packName: Doppel + prevname: "" + propagationLabels: + - all + toServerVersion: "" +description: |- + Doppel is a Modern Digital Risk Protection Solution, that detects the phishing and brand cyber attacks on the emerging channels. Doppel scans millions of channels online which includes, social media, domains, paid ads, dark web, emerging channels, etc. Doppel can identify the malicious content and cyber threats, and enables their customers to take down the digital risks proactively. + The XSOAR pack for Doppel mirrors the alerts created by Doppel as XSOAR incidents. The pack also contains the commands to perform different operations on Doppel alerts. +detaileddescription: |- + ### Get Started + + To use the app you need the following: + + 1. Doppel Tenant URL that you can use for calling the [Doppel APIs](https://doppel.readme.io/reference/create_alert). eg. *https://api.doppel.com/* + 2. API Key for calling Doppel + + Please reach out to Doppel to get access to above. + + Once you have the URL and API Key, use the same for configuring the Doppel-XSOAR integration instance. display: Doppel +image:  name: Doppel script: commands: - - name: get-alert - description: 'Retrieves the alert details by ID or entity. Must include exactly one of either id or entity' - arguments: - - name: id - description: 'The ID of the alert to retrieve details for' - required: false - - name: entity - description: 'The alerted entity to retrieve details for' - required: false + - arguments: + - description: The ID of the alert to retrieve details for + name: id + - description: The alerted entity to retrieve details for + name: entity + description: Retrieves the alert details by ID or entity. Must include exactly + one of either id or entity. + name: doppel-get-alert outputs: - contextPath: Doppel.doppel_link - description: 'Link to the alert in the Doppel portal' + description: Link to the alert in the Doppel portal type: String - - - name: get-alerts - description: Retrieves multiple alerts based on the query parameters provided. - It includes metadata and details about each alert. - arguments: - - name: search_key - description: Currently only supports search by url + - arguments: + - description: The entity for which the alert should be created. + name: entity + required: true + description: Creates an alert for a specified entity. This command requires the + entity to be provided in the arguments. + name: doppel-create-alert + outputs: + - contextPath: Doppel.CreatedAlert + description: The details of the created alert, including its unique ID and other + relevant metadata. + type: string + - arguments: + - description: The id of the alert to update + name: alert_id + - description: The entity of the alert to update + name: entity + type: unknown + - auto: PREDEFINED + description: Status of which queue the alert is in. + name: queue_state + predefined: + - doppel_review + - actioned + - needs_confirmation + - monitoring + - taken_down + - archived + type: textArea + - auto: PREDEFINED + description: State of the alert. + name: entity_state + predefined: + - active + - down + - parked + type: textArea + - name: comment + type: textArea + description: Updates an alert in the Doppel platform. + name: doppel-update-alert + outputs: + - contextPath: Doppel.UpdatedAlert + description: Provides details of the updated alert after modifying its queue_state + and entity_state. The result confirms the success and updates made. + type: unknown + - arguments: + - description: The entity for which the abuse alert should be created. + name: entity + required: true + description: Create an alert for the provided value to abuse box. Will fail if + the alert value is invalid or is protected. + name: doppel-create-abuse-alert + outputs: + - contextPath: Doppel.AbuseAlert + description: The details of the created abuse alert, including its unique ID + and other relevant metadata. + type: string + - arguments: + - description: Currently only supports search by url + name: search_key type: textArea - - name: queue_state - auto: PREDEFINED + - auto: PREDEFINED + description: New queue status to update alert with (id required) + name: queue_state predefined: - actioned - needs_confirmation @@ -49,9 +164,9 @@ script: - monitoring - taken_down - archived - description: New queue status to update alert with (id required) - - name: product - auto: PREDEFINED + - auto: PREDEFINED + description: Product category the report belongs to. + name: product predefined: - domains - social_media @@ -60,106 +175,46 @@ script: - crypto - emails - paid_adds - description: Product category the report belongs to. - - name: created_before - description: Filter alerts created before this date. '2024-01-05T13:45:30' -- + - description: Filter alerts created before this date. '2024-01-05T13:45:30' -- Represents the 5th of January 2024, at 1:45:30 PM + name: created_before type: textArea - - name: created_after - description: Filter alerts created after this date. '2024-01-05T13:45:30' -- + - description: Filter alerts created after this date. '2024-01-05T13:45:30' -- Represents the 5th of January 2024, at 1:45:30 PM + name: created_after type: textArea - - name: sort_type - auto: PREDEFINED + - auto: PREDEFINED + description: The field to sort the reports by. Defaults to date_sourced. + name: sort_type predefined: - date_sourced - date_last_actioned - description: The field to sort the reports by. Defaults to date_sourced. type: textArea - - name: sort_order - auto: PREDEFINED + - auto: PREDEFINED + description: The order to sort the reports by. Defaults to desc. + name: sort_order predefined: - asc - desc - description: The order to sort the reports by. Defaults to desc. type: textArea - - name: page - description: Page number for pagination; defaults to 0 + - description: Page number for pagination; defaults to 0 + name: page type: textArea - - name: tags - description: List of tags to filter alerts + - description: List of tags to filter alerts isArray: true + name: tags type: textArea + description: Retrieves a list of alerts. The result can be filtered by provided + parameters. + name: doppel-get-alerts outputs: - contextPath: Doppel.GetAlerts - - - - name: create-alert - description: Creates an alert for a specified entity. This command requires the - entity to be provided in the arguments. - arguments: - - name: entity - required: true - description: The entity for which the alert should be created. - outputs: - - contextPath: Doppel.CreatedAlert - description: The details of the created alert, including its unique ID and other - relevant metadata. - type: string - - - name: create-abuse-alert - description: Create an alert for the provided value to abuse box. Will fail if - the alert value is invalid or is protected - arguments: - - name: entity - required: true - description: The entity for which the abuse alert should be created. - outputs: - - contextPath: Doppel.AbuseAlert - description: The details of the created abuse alert, including its unique ID - and other relevant metadata. - type: string - - - - - name: update-alert - description: Updates a alert in the system with certain parameters. - arguments: - - name: alert_id - description: The id of the alert to update - - name: entity - description: The entity of the alert to update - type: unknown - - name: queue_state - auto: PREDEFINED - predefined: - - doppel_review - - actioned - - needs_confirmation - - monitoring - - taken_down - - archived - description: Status of which queue the alert is in. - type: textArea - - name: entity_state - auto: PREDEFINED - predefined: - - active - - down - - parked - description: State of the alert. - type: textArea - outputs: - - contextPath: Doppel.UpdatedAlert - description: Provides details of the updated alert after modifying its queue_state - and entity_state. The result confirms the success and updates made. + description: Retrieves multiple alerts based on the query parameters provided. + It includes metadata and details about each alert. type: unknown - - runonce: false - script: '-' - type: python - subtype: python3 - dockerimage: demisto/python3:3.12.7.117934 -fromversion: 5.5.0 -tests: -- No tests (auto formatted) + dockerimage: demisto/python3:3.10.14.100715 + isFetchSamples: true + isfetch: true + isremotesyncin: true + isremotesyncout: true + runonce: false \ No newline at end of file diff --git a/Packs/Doppel/Integrations/Doppel/Doppel_test.py b/Packs/Doppel/Integrations/Doppel/Doppel_test.py index d8c9166b2c4c..3d8dc4dbd72c 100644 --- a/Packs/Doppel/Integrations/Doppel/Doppel_test.py +++ b/Packs/Doppel/Integrations/Doppel/Doppel_test.py @@ -19,7 +19,7 @@ def util_load_json(path): @pytest.mark.parametrize("command, args, api_path, api_response", [ - ("get-alert", + ("doppel-get-alert", {"id": "TST-31222"}, "https://api.doppel.com/v1/alert?id=TST-31222", util_load_json('test_data/get-alert-success-200.json')) @@ -46,12 +46,12 @@ def test_command_success(mocker, requests_mock, command, args, api_path, api_res @pytest.mark.parametrize("command, args, api_path, status_code, api_response", [ - ("get-alert", + ("doppel-get-alert", {"entity": "123"}, "https://api.doppel.com/v1/alert?entity=123", 400, util_load_json('test_data/get-alert-failure-400-invalid-entity.json')), - ("get-alert", + ("doppel-get-alert", {"id": "1234"}, "https://api.doppel.com/v1/alert?id=1234", 400, @@ -81,12 +81,12 @@ def test_command_failure(mocker, requests_mock, command, args, api_path, status_ @pytest.mark.parametrize("command, args, api_path, status_code, exception_message", [ - ("get-alert", + ("doppel-get-alert", {"id": "TST-31", "entity": "http://dummyrul.com"}, "https://api.doppel.com/v1/alert?id=TST-31&entity=http://dummyrul.com", 400, - "Failed to execute get-alert command.\nError:\nBoth id and entity is specified. We need exactly single input for this command") + "Failed to execute doppel-get-alert command.\nError:\nBoth id and entity is specified. We need exactly single input for this command") ] ) def test_command_exception(mocker, requests_mock, command, args, api_path, status_code, exception_message): @@ -108,4 +108,4 @@ def test_command_exception(mocker, requests_mock, command, args, api_path, statu # Notice that the API was not called, but the app itself has raised an exception before making the API call assert adapter.call_count == 0 assert results_checker.call_args.args[0].get('Contents') == exception_message - + \ No newline at end of file diff --git a/Packs/Doppel/Integrations/Doppel/README.md b/Packs/Doppel/Integrations/Doppel/README.md index 5e9c90cb5b74..f56ee847e1f4 100644 --- a/Packs/Doppel/Integrations/Doppel/README.md +++ b/Packs/Doppel/Integrations/Doppel/README.md @@ -1,13 +1,10 @@ -# Doppel XSOAR Pack +### Get Started -## Overview -Doppel is a Modern Digital Risk Protection Solution, that detects the phishing and brand cyber attacks on the emerging channels. Doppel scans millions of channels online which includes, social media, domains, paid ads, dark web, emerging channels, etc. Doppel can identify the malicious content and cyber threats, and enables their customers to take down the digital risks proactively. +To use the app you need the following: -## Features supported by the Doppel XSOAR pack +1. Doppel Tenant URL that you can use for calling the [Doppel APIs](https://doppel.readme.io/reference/create_alert). eg. *https://api.doppel.com/* +2. API Key for calling Doppel -1. Mirror Incidents : Alerts from Doppel are mirrored as per the configured schedule. -2. Command: create-alert : Command to create an alert in Doppel. -3. Command: get-alert : Command to fetch alert details from Doppel. -4. Command: get-alerts : Command to fetch list of alerts from Doppel. -5. Command: update-alert : Command to update alert details from Doppel. -6. Command: create-abuse-alert : Command to create abuse alert details from Doppel. \ No newline at end of file +Please reach out to Doppel to get access to above. + +Once you have the URL and API Key, use the same for configuring the Doppel-XSOAR integration instance. \ No newline at end of file diff --git a/Packs/Doppel/classifier/classifier-Doppel_Incident_Classifier.json b/Packs/Doppel/classifier/classifier-Doppel_Incident_Classifier.json new file mode 100644 index 000000000000..a16812e17d4c --- /dev/null +++ b/Packs/Doppel/classifier/classifier-Doppel_Incident_Classifier.json @@ -0,0 +1,42 @@ +{ + "brands": null, + "cacheVersn": 0, + "defaultIncidentType": "", + "definitionId": "", + "description": "Doppel-XSOAR integration classifier to classify the fetched incidents to Doppel_Incident_Test.", + "feed": false, + "fromServerVersion": "", + "id": "607dc952-f37f-44d9-899f-16b0946230dd", + "incidentSamples": null, + "indicatorSamples": null, + "instanceIds": null, + "itemVersion": "", + "keyTypeMap": { + "crypto": "Doppel Alert Crypto", + "domains": "Doppel Alert Domains", + "ecommerce": "Doppel Alert Ecommerce", + "email": "Doppel Alert Email", + "mobile_apps": "Doppel Alert Mobile_Apps", + "paid_ads": "Doppel Alert Paid_Ads", + "social_media": "Doppel Alert Social_Media" + }, + "locked": false, + "logicalVersion": 6, + "mapping": null, + "name": "Doppel_Incident_Classifier", + "nameRaw": "Doppel_Incident_Classifier", + "packID": "", + "packName": "", + "propagationLabels": [ + "all" + ], + "sourceClassifierId": "", + "system": false, + "toServerVersion": "", + "transformer": { + "simple": "product" + }, + "type": "classification", + "unclassifiedCases": null, + "version": -1 +} \ No newline at end of file diff --git a/Packs/Doppel/classifier/classifier-Doppel_Incoming_Mapper.json b/Packs/Doppel/classifier/classifier-Doppel_Incoming_Mapper.json new file mode 100644 index 000000000000..bda79cf996a3 --- /dev/null +++ b/Packs/Doppel/classifier/classifier-Doppel_Incoming_Mapper.json @@ -0,0 +1,423 @@ +{ + "brands": null, + "cacheVersn": 0, + "defaultIncidentType": "", + "definitionId": "", + "description": "", + "feed": false, + "fromServerVersion": "", + "id": "c1af4cac-ec08-426f-880d-9fefee0fc672", + "incidentSamples": null, + "indicatorSamples": null, + "instanceIds": null, + "itemVersion": "1.0.0", + "keyTypeMap": {}, + "locked": false, + "logicalVersion": 21, + "mapping": { + "Doppel Alert": { + "dontMapEventToLabels": false, + "internalMapping": { + "Additional Indicators": { + "simple": "entity" + }, + "Alert ID": { + "simple": "id" + }, + "Alert Source": { + "simple": "source" + }, + "Alert tags": { + "simple": "tags" + }, + "Audit Log History": { + "simple": "audit_logs" + }, + "Block Indicators Status": { + "simple": "entity_state" + }, + "External Link": { + "simple": "doppel_link" + }, + "External Severity": { + "simple": "severity" + }, + "Selected Indicators": { + "simple": "entity" + }, + "Source Created By": { + "simple": "uploaded_by" + }, + "State": { + "simple": "queue_state" + }, + "Vulnerable Product": { + "simple": "brand" + }, + "created_at": { + "simple": "created_at" + }, + "entity": { + "simple": "entity" + }, + "entity_content.root_domain.contact_email": { + "simple": "entity_content.root_domain.contact_email" + }, + "entity_content.root_domain.country_code": { + "simple": "entity_content.root_domain.country_code" + }, + "entity_content.root_domain.domain": { + "simple": "entity_content.root_domain.domain" + }, + "entity_content.root_domain.hosting_provider": { + "simple": "entity_content.root_domain.hosting_provider" + }, + "entity_content.root_domain.ip_address": { + "simple": "entity_content.root_domain.ip_address" + }, + "entity_content.root_domain.mx_records": { + "simple": "mx_records" + }, + "entity_content.root_domain.nameservers\t": { + "simple": "nameservers" + }, + "entity_content.root_domain.registrar\t": { + "simple": "entity_content.root_domain.registrar" + }, + "entity_state": { + "simple": "entity_state" + }, + "notes": { + "simple": "notes" + }, + "platform": { + "simple": "platform" + }, + "product": { + "simple": "product" + }, + "queue_state": { + "simple": "queue_state" + }, + "severity": { + "simple": "severity" + }, + "source": { + "simple": "source" + }, + "sourceBrand": { + "simple": "brand" + }, + "uploaded_by": { + "simple": "uploaded_by" + } + } + }, + "Doppel Alert Test": { + "dontMapEventToLabels": false, + "internalMapping": { + "Additional Indicators": { + "simple": "entity" + }, + "Alert ID": { + "simple": "id" + }, + "Alert Source": { + "simple": "source" + }, + "Alert tags": { + "simple": "tags" + }, + "Audit Log History": { + "simple": "audit_logs" + }, + "Block Indicators Status": { + "simple": "entity_state" + }, + "External Link": { + "simple": "doppel_link" + }, + "External Severity": { + "simple": "severity" + }, + "Selected Indicators": { + "simple": "entity" + }, + "Source Created By": { + "simple": "uploaded_by" + }, + "State": { + "simple": "queue_state" + }, + "Vulnerable Product": { + "simple": "brand" + }, + "created_at": { + "simple": "created_at" + }, + "entity": { + "simple": "entity" + }, + "entity_content.root_domain.contact_email": { + "simple": "entity_content.root_domain.contact_email" + }, + "entity_content.root_domain.country_code": { + "simple": "entity_content.root_domain.country_code" + }, + "entity_content.root_domain.domain": { + "simple": "entity_content.root_domain.domain" + }, + "entity_content.root_domain.hosting_provider": { + "simple": "entity_content.root_domain.hosting_provider" + }, + "entity_content.root_domain.ip_address": { + "simple": "entity_content.root_domain.ip_address" + }, + "entity_content.root_domain.mx_records": { + "simple": "mx_records" + }, + "entity_content.root_domain.nameservers\t": { + "simple": "nameservers" + }, + "entity_content.root_domain.registrar\t": { + "simple": "entity_content.root_domain.registrar" + }, + "entity_state": { + "simple": "entity_state" + }, + "notes": { + "simple": "notes" + }, + "platform": { + "simple": "platform" + }, + "product": { + "simple": "product" + }, + "queue_state": { + "simple": "queue_state" + }, + "severity": { + "simple": "severity" + }, + "source": { + "simple": "source" + }, + "sourceBrand": { + "simple": "brand" + }, + "uploaded_by": { + "simple": "uploaded_by" + } + } + }, + "dbot_classification_incident_type_all": { + "dontMapEventToLabels": true, + "internalMapping": { + "Additional Indicators": { + "simple": "entity" + }, + "Audit Logs": { + "simple": "audit_logs.[]." + }, + "Audit_logs_History": { + "simple": "audit_logs.[]" + }, + "Audit_logs_info": { + "simple": "audit_logs.[]" + }, + "Block Indicators Status": { + "simple": "entity_state" + }, + "Created At": { + "simple": "created_at" + }, + "Doppel Alert Brand": { + "simple": "brand" + }, + "Doppel Alert ID": { + "simple": "id" + }, + "Doppel Audit Logs": { + "simple": "audit_logs.[]." + }, + "Doppel Brand": { + "simple": "brand" + }, + "Doppel Created At": { + "simple": "created_at" + }, + "Doppel Entity": { + "simple": "entity" + }, + "Doppel Entity Content": { + "simple": "entity_content.root_domain" + }, + "Doppel Entity Content Contact Email": { + "simple": "entity_content.root_domain.contact_email" + }, + "Doppel Entity Content Country Code": { + "simple": "entity_content.root_domain.country_code" + }, + "Doppel Entity Content Domain": { + "simple": "entity_content.root_domain.domain" + }, + "Doppel Entity Content Hosting Provider": { + "simple": "entity_content.root_domain.hosting_provider" + }, + "Doppel Entity Content IP Address": { + "simple": "entity_content.root_domain.ip_address" + }, + "Doppel Entity Content MX Records": { + "simple": "entity_content.root_domain.mx_records.[]." + }, + "Doppel Entity Content Name Servers": { + "simple": "entity_content.root_domain.nameservers.[]." + }, + "Doppel Entity Content Registrar": { + "simple": "entity_content.root_domain.registrar" + }, + "Doppel Entity State": { + "simple": "entity_state" + }, + "Doppel Link": { + "simple": "doppel_link" + }, + "Doppel Notes": { + "simple": "notes" + }, + "Doppel Platform": { + "simple": "platform" + }, + "Doppel Product": { + "simple": "product" + }, + "Doppel Queue State": { + "simple": "queue_state" + }, + "Doppel Severity": { + "simple": "severity" + }, + "Doppel Source": { + "simple": "source" + }, + "Doppel Tags": { + "simple": "tags" + }, + "Doppel Uploaded By": { + "simple": "uploaded_by" + }, + "Entity": { + "simple": "entity" + }, + "Entity Content": { + "simple": "entity_content" + }, + "Entity State": { + "simple": "entity_state" + }, + "External Link": { + "simple": "doppel_link" + }, + "External Severity": { + "simple": "severity" + }, + "Notes": { + "simple": "notes" + }, + "Platform": { + "simple": "platform" + }, + "Product": { + "simple": "product" + }, + "Queue State": { + "simple": "queue_state" + }, + "Selected Indicators": { + "simple": "entity" + }, + "Source Created By": { + "simple": "uploaded_by" + }, + "State": { + "simple": "queue_state" + }, + "Tags": { + "simple": "tags" + }, + "Test Entity Content": { + "simple": "entity_content.root_domain" + }, + "Uploaded By": { + "simple": "uploaded_by" + }, + "Vulnerable Product": { + "simple": "brand" + }, + "created_at": { + "simple": "created_at" + }, + "dbotMirrorDirection": { + "simple": "mirror_direction" + }, + "dbotMirrorId": { + "simple": "id" + }, + "dbotMirrorInstance": { + "simple": "mirror_instance" + }, + "entity": { + "simple": "entity" + }, + "entity_content.root_domain.registrar\t": { + "simple": "entity_content.root_domain.registrar" + }, + "entity_state": { + "simple": "entity_state" + }, + "notes": { + "simple": "notes" + }, + "occurred": { + "simple": "created_at" + }, + "platform": { + "simple": "platform" + }, + "product": { + "simple": "product" + }, + "queue_state": { + "simple": "queue_state" + }, + "severity": { + "simple": "severity" + }, + "source": { + "simple": "source" + }, + "sourceBrand": { + "simple": "brand" + }, + "uploaded_by": { + "simple": "uploaded_by" + } + } + } + }, + "name": "Doppel Incoming_Mapper", + "nameRaw": "Doppel Incoming_Mapper", + "packID": "", + "packName": "Doppel", + "propagationLabels": [ + "all" + ], + "sourceClassifierId": "d1d1bfa4-c898-4eae-8a72-1e36d11ebbf2", + "system": false, + "toServerVersion": "", + "transformer": {}, + "type": "mapping-incoming", + "unclassifiedCases": null, + "version": -1 +} \ No newline at end of file diff --git a/Packs/Doppel/classifier/classifier-Doppel_Outgoing_Mapper.json b/Packs/Doppel/classifier/classifier-Doppel_Outgoing_Mapper.json new file mode 100644 index 000000000000..9d62cdae7907 --- /dev/null +++ b/Packs/Doppel/classifier/classifier-Doppel_Outgoing_Mapper.json @@ -0,0 +1,49 @@ +{ + "brands": null, + "cacheVersn": 0, + "defaultIncidentType": "", + "definitionId": "", + "description": "", + "feed": false, + "fromServerVersion": "", + "id": "e0e1f85a-55c1-46f8-8cba-f27c9b438322", + "incidentSamples": null, + "indicatorSamples": null, + "instanceIds": null, + "itemVersion": "1.0.0", + "keyTypeMap": {}, + "locked": false, + "logicalVersion": 2, + "mapping": { + "Doppel Alert": { + "dontMapEventToLabels": false, + "internalMapping": { + "queue_state": { + "simple": "queuestate" + } + } + }, + "dbot_classification_incident_type_all": { + "dontMapEventToLabels": false, + "internalMapping": { + "Queue State": { + "simple": "labels.queue_state" + } + } + } + }, + "name": "Doppel Outgoing_Mapper", + "nameRaw": "Doppel Outgoing_Mapper", + "packID": "", + "packName": "Doppel", + "propagationLabels": [ + "all" + ], + "sourceClassifierId": "602a520c-d5d3-45c8-8cd8-5fbbaa6e93ed", + "system": false, + "toServerVersion": "", + "transformer": {}, + "type": "mapping-outgoing", + "unclassifiedCases": null, + "version": -1 +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Alert_ID.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Alert_ID.json new file mode 100644 index 000000000000..279899577437 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Alert_ID.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelalertid", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelalertid", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Alert ID", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Audit_Logs.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Audit_Logs.json new file mode 100644 index 000000000000..02f4f5a878ee --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Audit_Logs.json @@ -0,0 +1,136 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": [], + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelauditlogs", + "closeForm": false, + "columns": [ + { + "displayName": "changed_by", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "changed_by", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "timestamp", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "timestamp", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "type", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "type", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "value", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "value", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "metadata", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "metadata", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + } + ], + "content": false, + "defaultRows": [ + {}, + {}, + {} + ], + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelauditlogs", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Audit Logs", + "neverSetAsRequired": false, + "openEnded": true, + "orgType": "grid", + "ownerOnly": false, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "placeholder": "", + "pretty_name": "Doppel Audit Logs", + "propagationLabels": [ + "all" + ], + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "grid", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Brand.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Brand.json new file mode 100644 index 000000000000..8baaa1a4d0fc --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Brand.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": [], + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelbrand", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelbrand", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Brand", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "shortText", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "Doppel Brand", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Created_At.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Created_At.json new file mode 100644 index 000000000000..285a9ac7bec8 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Created_At.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelcreatedat", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelcreatedat", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Created At", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity.json new file mode 100644 index 000000000000..24ab6f94e169 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelentity", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelentity", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Entity", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "url", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_Content.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_Content.json new file mode 100644 index 000000000000..20ad2b470515 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_Content.json @@ -0,0 +1,173 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": [], + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelentitycontent", + "closeForm": false, + "columns": [ + { + "displayName": "domain", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "domain", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "registrar", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "registrar", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "ip_address", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "ip_address", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "contact_email", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "contact_email", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "country_code", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "country_code", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "hosting_provider", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "hosting_provider", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "mx_records", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "mx_records", + "orgType": "", + "required": false, + "script": "", + "selectValues": [], + "type": "longText", + "width": 150 + }, + { + "displayName": "nameservers", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "nameservers", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "longText", + "width": 150 + } + ], + "content": false, + "defaultRows": [ + {} + ], + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelentitycontent", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Entity Content", + "neverSetAsRequired": false, + "openEnded": true, + "orgType": "grid", + "ownerOnly": false, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "placeholder": "", + "pretty_name": "Doppel Entity Content", + "propagationLabels": [ + "all" + ], + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "grid", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_State.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_State.json new file mode 100644 index 000000000000..a502d8b81194 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Entity_State.json @@ -0,0 +1,68 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": [], + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelentitystate", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelentitystate", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Entity State", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "singleSelect", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "Doppel Entity State", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": [ + "", + "active", + "parked", + "down" + ], + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "singleSelect", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Link.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Link.json new file mode 100644 index 000000000000..611996069f0f --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Link.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppellink", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppellink", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Link", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "url", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Notes.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Notes.json new file mode 100644 index 000000000000..9a95515487b7 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Notes.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelnotes", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelnotes", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Notes", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "shortText", + "ownerOnly": true, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "ce08360d623c7147d2e224b52c30bf2e", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Platform.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Platform.json new file mode 100644 index 000000000000..88534a30af60 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Platform.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelplatform", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelplatform", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Platform", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Product.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Product.json new file mode 100644 index 000000000000..3e13068fb11f --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Product.json @@ -0,0 +1,72 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": [], + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelproduct", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelproduct", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Product", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "singleSelect", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "Doppel Product", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": [ + "", + "domains", + "social_media", + "mobile_apps", + "ecommerce", + "crypto", + "email", + "paid_ads" + ], + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "singleSelect", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Queue_State.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Queue_State.json new file mode 100644 index 000000000000..20bb352696ef --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Queue_State.json @@ -0,0 +1,71 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelqueuestate", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelqueuestate", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Queue State", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": [ + "", + "doppel_review", + "needs_confirmation", + "actioned", + "archived", + "monitoring", + "taken_down" + ], + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "singleSelect", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Severity.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Severity.json new file mode 100644 index 000000000000..f87389ffdef4 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Severity.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelseverity", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelseverity", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Severity", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Source.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Source.json new file mode 100644 index 000000000000..665df198126f --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Source.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppelsource", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppelsource", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Source", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Tags.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Tags.json new file mode 100644 index 000000000000..24846e11fda8 --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Tags.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppeltags", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppeltags", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Tags", + "neverSetAsRequired": false, + "openEnded": true, + "orgType": "", + "ownerOnly": false, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": [], + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "multiSelect", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidentfield/incidentfield-Doppel_Uploaded_By.json b/Packs/Doppel/incidentfield/incidentfield-Doppel_Uploaded_By.json new file mode 100644 index 000000000000..f3ea72f821ac --- /dev/null +++ b/Packs/Doppel/incidentfield/incidentfield-Doppel_Uploaded_By.json @@ -0,0 +1,63 @@ +{ + "XDRBuiltInField": false, + "XsiamIncidentFieldExtraData": { + "incidentsFilter": null, + "slaGoals": null, + "slaTimer": null, + "timerConditions": null + }, + "aliasTo": "", + "aliases": null, + "associatedToAll": true, + "associatedTypes": null, + "autoCompleteTags": null, + "breachScript": "", + "cacheVersn": 0, + "caseInsensitive": true, + "cliName": "doppeluploadedby", + "closeForm": false, + "columns": null, + "content": false, + "defaultRows": null, + "definitionId": "", + "description": "", + "editForm": true, + "fieldCalcScript": "", + "fromServerVersion": "", + "group": 0, + "hidden": false, + "id": "incident_doppeluploadedby", + "ipVersion": "", + "isReadOnly": false, + "itemVersion": "", + "locked": false, + "mergeStrategy": "", + "name": "Doppel Uploaded By", + "neverSetAsRequired": false, + "openEnded": false, + "orgType": "", + "ownerOnly": true, + "packID": "aba8d875-96b4-472e-8608-84cba2ece652", + "packName": "Incident Fields", + "placeholder": "", + "pretty_name": "", + "required": false, + "runScriptAfterUpdate": false, + "script": "", + "selectValues": null, + "selectValuesMap": null, + "sla": 0, + "system": false, + "systemAssociatedTypes": null, + "template": "", + "threshold": 72, + "toServerVersion": "", + "type": "shortText", + "unmapped": false, + "unsearchable": false, + "useAsKpi": false, + "validatedError": "", + "validationRegex": "", + "version": -1, + "x2_fields": "" +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Crypto.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Crypto.json new file mode 100644 index 000000000000..2cc800c80041 --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Crypto.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#CD034C", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Crypto", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Crypto", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Domains.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Domains.json new file mode 100644 index 000000000000..d1d3675245e9 --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Domains.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#9FA8DA", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Domains", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Domains", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Ecommerce.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Ecommerce.json new file mode 100644 index 000000000000..367052f1c4da --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Ecommerce.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#4B897A", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Ecommerce", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Ecommerce", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Email.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Email.json new file mode 100644 index 000000000000..0c7a8688d05e --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Email.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#7D28A7", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Email", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Email", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Mobile_Apps.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Mobile_Apps.json new file mode 100644 index 000000000000..57cdee98f8ad --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Mobile_Apps.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#3D8EB3", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Mobile_Apps", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Mobile_Apps", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Paid_Ads.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Paid_Ads.json new file mode 100644 index 000000000000..64783f73e9bb --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Paid_Ads.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#E46BCD", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Paid_Ads", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Paid_Ads", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Social_Media.json b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Social_Media.json new file mode 100644 index 000000000000..1e8779b66c9e --- /dev/null +++ b/Packs/Doppel/incidenttype/incidenttype-Doppel_Alert_Social_Media.json @@ -0,0 +1,38 @@ +{ + "autorun": false, + "cacheVersn": 0, + "closureScript": "", + "color": "#EEC1C1", + "days": 0, + "daysR": 0, + "default": false, + "definitionId": "", + "detached": false, + "disabled": false, + "extractSettings": { + "fieldCliNameToExtractSettings": {}, + "mode": "Specific" + }, + "fromServerVersion": "", + "hours": 0, + "hoursR": 0, + "id": "Doppel Alert Social_Media", + "itemVersion": "", + "layout": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "locked": false, + "name": "Doppel Alert Social_Media", + "onChangeRepAlg": 0, + "packID": "248d399d-20e5-4697-8896-6f05664b8187", + "packName": "Doppel_Incident_Classifier Contribution Pack", + "preProcessingScript": "", + "propagationLabels": [ + "all" + ], + "readonly": false, + "reputationCalc": 0, + "system": false, + "toServerVersion": "", + "version": -1, + "weeks": 0, + "weeksR": 0 +} \ No newline at end of file diff --git a/Packs/Doppel/layoutscontainer/layoutscontainer-Doppel_Incident_Layout.json b/Packs/Doppel/layoutscontainer/layoutscontainer-Doppel_Incident_Layout.json new file mode 100644 index 000000000000..540b1bfd852f --- /dev/null +++ b/Packs/Doppel/layoutscontainer/layoutscontainer-Doppel_Incident_Layout.json @@ -0,0 +1,902 @@ +{ + "cacheVersn": 0, + "close": null, + "definitionId": "", + "description": "", + "detached": false, + "details": null, + "detailsV2": { + "TypeName": "", + "tabs": [ + { + "id": "summary", + "name": "Legacy Summary", + "type": "summary" + }, + { + "id": "caseinfoid", + "name": "Incident Info", + "sections": [ + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-fce71720-98b0-11e9-97d7-ed26ef9e46c8", + "isVisible": true, + "items": [ + { + "endCol": 2, + "fieldId": "type", + "height": 26, + "id": "incident-type-field", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "severity", + "height": 26, + "id": "incident-severity-field", + "index": 1, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "owner", + "height": 26, + "id": "incident-owner-field", + "index": 2, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "sourcebrand", + "height": 26, + "id": "incident-sourceBrand-field", + "index": 4, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "sourceinstance", + "height": 26, + "id": "incident-sourceInstance-field", + "index": 5, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "playbookid", + "height": 26, + "id": "incident-playbookId-field", + "index": 6, + "sectionItemType": "field", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Case Details", + "static": false, + "w": 1, + "x": 0, + "y": 0 + }, + { + "h": 2, + "i": "caseinfoid-61263cc0-98b1-11e9-97d7-ed26ef9e46c8", + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Notes", + "static": false, + "type": "notes", + "w": 1, + "x": 2, + "y": 0 + }, + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-6aabad20-98b1-11e9-97d7-ed26ef9e46c8", + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Work Plan", + "static": false, + "type": "workplan", + "w": 1, + "x": 1, + "y": 0 + }, + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-770ec200-98b1-11e9-97d7-ed26ef9e46c8", + "isVisible": true, + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Linked Incidents", + "static": false, + "type": "linkedIncidents", + "w": 1, + "x": 1, + "y": 6 + }, + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-842632c0-98b1-11e9-97d7-ed26ef9e46c8", + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Child Incidents", + "static": false, + "type": "childInv", + "w": 1, + "x": 2, + "y": 4 + }, + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-4a31afa0-98ba-11e9-a519-93a53c759fe0", + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Evidence", + "static": false, + "type": "evidence", + "w": 1, + "x": 2, + "y": 2 + }, + { + "displayType": "ROW", + "h": 2, + "hideName": false, + "i": "caseinfoid-7717e580-9bed-11e9-9a3f-8b4b2158e260", + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Team Members", + "static": false, + "type": "team", + "w": 1, + "x": 2, + "y": 6 + }, + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-7ce69dd0-a07f-11e9-936c-5395a1acf11e", + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Indicators", + "query": "", + "queryType": "input", + "static": false, + "type": "indicators", + "w": 2, + "x": 0, + "y": 4 + }, + { + "displayType": "CARD", + "h": 2, + "i": "caseinfoid-ac32f620-a0b0-11e9-b27f-13ae1773d289", + "items": [ + { + "endCol": 1, + "fieldId": "occurred", + "height": 26, + "id": "incident-occurred-field", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 1, + "fieldId": "dbotmodified", + "height": 26, + "id": "incident-modified-field", + "index": 1, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "dbotduedate", + "height": 26, + "id": "incident-dueDate-field", + "index": 2, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "dbotcreated", + "height": 26, + "id": "incident-created-field", + "index": 0, + "sectionItemType": "field", + "startCol": 1 + }, + { + "endCol": 2, + "fieldId": "dbotclosed", + "height": 26, + "id": "incident-closed-field", + "index": 1, + "sectionItemType": "field", + "startCol": 1 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Timeline Information", + "static": false, + "w": 1, + "x": 0, + "y": 2 + }, + { + "displayType": "ROW", + "h": 2, + "i": "caseinfoid-88e6bf70-a0b1-11e9-b27f-13ae1773d289", + "isVisible": true, + "items": [ + { + "endCol": 2, + "fieldId": "dbotclosed", + "height": 26, + "id": "incident-dbotClosed-field", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "closereason", + "height": 26, + "id": "incident-closeReason-field", + "index": 1, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "closenotes", + "height": 26, + "id": "incident-closeNotes-field", + "index": 2, + "sectionItemType": "field", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Closing Information", + "static": false, + "w": 1, + "x": 0, + "y": 6 + }, + { + "displayType": "CARD", + "h": 2, + "i": "caseinfoid-e54b1770-a0b1-11e9-b27f-13ae1773d289", + "isVisible": true, + "items": [ + { + "endCol": 2, + "fieldId": "details", + "height": 26, + "id": "incident-details-field", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Investigation Data", + "static": false, + "w": 1, + "x": 1, + "y": 2 + } + ], + "type": "custom" + }, + { + "id": "warRoom", + "name": "War Room", + "type": "warRoom" + }, + { + "id": "workPlan", + "name": "Work Plan", + "type": "workPlan" + }, + { + "id": "evidenceBoard", + "name": "Evidence Board", + "type": "evidenceBoard" + }, + { + "id": "canvas", + "name": "Canvas", + "type": "canvas" + }, + { + "hidden": false, + "id": "chtyrfjhpp", + "name": "Doppel Alert Data", + "sections": [ + { + "description": "Details about the alert fetched from the Doppel platform", + "displayType": "ROW", + "h": 4, + "hideName": false, + "i": "chtyrfjhpp-6cccc2bd-1312-44b7-8ab4-2e23aae407a7", + "items": [ + { + "endCol": 2, + "fieldId": "doppelalertid", + "height": 26, + "id": "a6ce5d89-5115-4f48-b430-d33799081c52", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelseverity", + "height": 26, + "id": "2feff9ff-9c80-4aed-8866-abf3892a2fa6", + "index": 1, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelbrand", + "height": 26, + "id": "31921aa2-3b76-4b3a-a6d3-5f1e43968dcb", + "index": 2, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "brand", + "height": 26, + "id": "5f7dc687-7405-4465-a603-fbab6c1e4686", + "index": 3, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "entitystate", + "height": 26, + "id": "dbd066f4-285b-4a9a-9467-50671f5a2915", + "index": 3, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "queuestate", + "height": 26, + "id": "27e8a019-7828-4406-93b9-dbf951f71a7a", + "index": 3, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "product", + "height": 26, + "id": "079c3ec9-f0a9-4673-8aa5-4e4c9e9e79cf", + "index": 3, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "platform", + "height": 26, + "id": "d2ad1638-1c98-4e96-a52e-561c72297fa6", + "index": 3, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppellink", + "height": 26, + "id": "128d659a-5c63-458c-a96b-0240bbeae842", + "index": 3, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelnotes", + "height": 26, + "id": "a144e1c1-b303-4dcb-b56d-d89508e3ccd1", + "index": 4, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelplatform", + "height": 26, + "id": "30e0153f-6343-44eb-b9ca-c4dea0e82161", + "index": 5, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelproduct", + "height": 26, + "id": "edcef656-d794-4f5c-9fed-5b583384d3ea", + "index": 6, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelqueuestate", + "height": 26, + "id": "820d34e6-33ef-4990-9345-865772efc7a1", + "index": 7, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelcreatedat", + "height": 26, + "id": "270e7ec6-6db4-43ce-9f88-6d16e08649f9", + "index": 8, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelsource", + "height": 26, + "id": "bd17abba-3f1f-4159-ab0e-9645d32c3c66", + "index": 10, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppeltags", + "height": 26, + "id": "98baebf3-14e6-445c-ae21-91664a795ade", + "index": 10, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppeluploadedby", + "height": 26, + "id": "baaf1629-2c6e-4f54-9970-16aac380b407", + "index": 11, + "sectionItemType": "field", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Alert Details", + "static": false, + "w": 1, + "x": 0, + "y": 0 + }, + { + "columns": [ + { + "displayName": "domain", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "domain", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 182 + }, + { + "displayName": "registrar", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "registrar", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 124 + }, + { + "displayName": "ip_address", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "ip_address", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 118 + }, + { + "displayName": "contact_email", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "contact_email", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 150 + }, + { + "displayName": "country_code", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "country_code", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 122 + }, + { + "displayName": "hosting_provider", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "hosting_provider", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "shortText", + "width": 151 + }, + { + "displayName": "mx_records", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "mx_records", + "orgType": "", + "required": false, + "script": "", + "selectValues": [], + "type": "longText", + "width": 120 + }, + { + "displayName": "nameservers", + "fieldCalcScript": "", + "isDefault": true, + "isReadOnly": false, + "key": "nameservers", + "orgType": "", + "required": false, + "script": "", + "selectValues": null, + "type": "longText", + "width": 264 + } + ], + "description": "Details about the entity received from Doppel", + "displayType": "ROW", + "h": 3, + "hideName": false, + "i": "chtyrfjhpp-db82b87b-a67c-4e81-8e33-29dae245ea1b", + "items": [ + { + "endCol": 2, + "fieldId": "entitycontentrootdomainregistrar", + "height": 26, + "id": "f9107076-5e95-4c45-83ef-9c014570de24", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelentity", + "height": 26, + "id": "1bfc1bbf-f0cd-4b97-af72-0c2dc7db87e6", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + }, + { + "endCol": 2, + "fieldId": "doppelentitystate", + "height": 26, + "id": "f36bf862-77df-4d6d-be09-9079492ef44c", + "index": 1, + "sectionItemType": "field", + "startCol": 0 + }, + { + "dropEffect": "move", + "endCol": 4, + "fieldId": "doppelentitycontent", + "height": 106, + "id": "4c377f5a-6dcf-4122-8112-4fb557f4642b", + "index": 2, + "listId": "chtyrfjhpp-db82b87b-a67c-4e81-8e33-29dae245ea1b", + "sectionItemType": "field", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Entity Content", + "static": false, + "w": 2, + "x": 1, + "y": 0 + }, + { + "description": "Shows the Audit log history for the particular Alert", + "displayType": "ROW", + "h": 4, + "hideName": false, + "i": "chtyrfjhpp-07b54ffa-28e8-4216-b4d2-1d0590a0affe", + "items": [ + { + "endCol": 4, + "fieldId": "doppelauditlogs", + "height": 106, + "id": "e211b223-1b57-4d29-b3cb-1bd7b7fd6475", + "index": 0, + "sectionItemType": "field", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Audit Log History", + "static": false, + "w": 2, + "x": 1, + "y": 3 + }, + { + "description": "Provides the Action buttons to Modify the Queue_State value with a suitable comment", + "displayType": "ROW", + "h": 3, + "hideName": false, + "i": "chtyrfjhpp-46dd786d-8134-4c56-ab8e-f630302f49ee", + "items": [ + { + "args": { + "alert_id": { + "simple": "${incident.doppelalertid}" + }, + "comment": { + "simple": " ", + "userMarkedRequired": true + }, + "entity_state": { + "simple": "${incident.doppelentitystate}", + "userMarkedRequired": false + }, + "queue_state": { + "simple": "actioned", + "userMarkedRequired": false + }, + "using": { + "simple": "Doppel_Mirroring_Test_instance_1" + } + }, + "endCol": 2, + "fieldId": "", + "height": 44, + "id": "5519ca81-081e-4b00-9d88-fadabc959528", + "index": 0, + "name": "Request Takedown", + "scriptId": "Doppel_Mirroring_Test|||doppel-update-alert", + "sectionItemType": "button", + "startCol": 0 + }, + { + "args": { + "alert_id": { + "simple": "${incident.doppelalertid}" + }, + "comment": { + "simple": "Safelist this Asset, we own it.", + "userMarkedRequired": true + }, + "entity_state": { + "simple": "${incident.doppelentitystate}" + }, + "queue_state": { + "simple": "doppel_review" + }, + "using": { + "simple": "Doppel_Mirroring_Test_instance_1" + } + }, + "dropEffect": "move", + "endCol": 2, + "fieldId": "", + "height": 44, + "id": "5d2778f2-8950-47da-a023-4f81bf3c5d41", + "index": 1, + "listId": "chtyrfjhpp-46dd786d-8134-4c56-ab8e-f630302f49ee", + "name": "Safelist the Asset", + "scriptId": "Doppel_Mirroring_Test|||doppel-update-alert", + "sectionItemType": "button", + "startCol": 0 + }, + { + "args": { + "alert_id": { + "simple": "${incident.doppelalertid}" + }, + "comment": { + "simple": "Throw out this Alert later \nas this is a Noise.", + "userMarkedRequired": true + }, + "entity_state": { + "simple": "${incident.doppelentitystate}", + "userMarkedRequired": false + }, + "queue_state": { + "simple": "doppel_review" + }, + "using": { + "simple": "Doppel_Mirroring_Test_instance_1" + } + }, + "dropEffect": "move", + "endCol": 2, + "fieldId": "", + "height": 44, + "id": "78e9d1ce-d4b5-46bc-908a-200338c3dc97", + "index": 2, + "listId": "chtyrfjhpp-46dd786d-8134-4c56-ab8e-f630302f49ee", + "name": "False Positive", + "scriptId": "Doppel_Mirroring_Test|||doppel-update-alert", + "sectionItemType": "button", + "startCol": 0 + }, + { + "args": { + "alert_id": { + "simple": "${incident.doppelalertid}" + }, + "comment": { + "simple": " ", + "userMarkedRequired": true + }, + "entity_state": { + "simple": "${incident.doppelentitystate}", + "userMarkedRequired": false + }, + "queue_state": { + "simple": "archived" + }, + "using": { + "simple": "Doppel_Mirroring_Test_instance_1" + } + }, + "endCol": 2, + "fieldId": "", + "height": 44, + "id": "1c5f3d2d-8098-42b7-bfb1-d7fb61f3438e", + "index": 3, + "name": "Archive", + "scriptId": "Doppel_Mirroring_Test|||doppel-update-alert", + "sectionItemType": "button", + "startCol": 0 + }, + { + "args": { + "alert_id": { + "simple": "${incident.doppelalertid}" + }, + "comment": { + "simple": " ", + "userMarkedRequired": true + }, + "entity_state": { + "simple": "${incident.doppelentitystate}", + "userMarkedRequired": false + }, + "queue_state": { + "simple": "monitoring" + }, + "using": { + "simple": "Doppel_Mirroring_Test_instance_1" + } + }, + "dropEffect": "move", + "endCol": 2, + "fieldId": "", + "height": 44, + "id": "e4c1e702-00ca-4e8d-8c92-dfc2a2d8bec9", + "index": 4, + "listId": "chtyrfjhpp-46dd786d-8134-4c56-ab8e-f630302f49ee", + "name": "Monitor", + "scriptId": "Doppel_Mirroring_Test|||doppel-update-alert", + "sectionItemType": "button", + "startCol": 0 + } + ], + "maxW": 3, + "minH": 1, + "moved": false, + "name": "Actions", + "static": false, + "w": 1, + "x": 0, + "y": 4 + } + ], + "type": "custom" + } + ] + }, + "edit": null, + "fromServerVersion": "0.0.0", + "group": "incident", + "id": "21fa7f00-205f-4c4d-80c6-c858e09f1e0a", + "indicatorsDetails": null, + "indicatorsQuickView": null, + "itemVersion": "1.0.0", + "locked": false, + "mobile": null, + "name": "Doppel Incident Layout", + "packID": "", + "packName": "Doppel", + "propagationLabels": [ + "all" + ], + "quickView": null, + "quickViewV2": null, + "system": false, + "toServerVersion": "99.99.99", + "version": -1 +} \ No newline at end of file