Overview

Provides the ability to render templates using Jinja2. Jinja2 provides fast and flexible ways to create rich templates. These templates can be used in entity insights, emails, ticketing systems, or any action that can take in a text string. Jinja2 documentation can be found at https://jinja.palletsprojects.com/en/2.11.x/.

Actions

Entity Insight

Description

Creates entity insights from a JSON object using a Jinja2 template.

Parameters

ParameterTypeDefault ValueIs MandatoryDescription
JSON ObjectJSONN/AYesSpecify the raw JSON object that will be used to render the template.
TemplateDropdownSMRT Table CSSNoSpecify the Jinja2 Template to display. It can be a HTML template from “Settings->environment” or added in the content box.
Triggered ByStringSiemplifyYesSpecify the name of the integration that triggered this entity insight.
Remove BRsCheckboxUncheckedNoSpecify whether you want to remove all <br> html tags from the rendered template.
Create InsightCheckboxCheckedNoSpecify whether you want to create an entity insight.

Example

In this scenario, we’re creating an insight using a json object which includes entity identifier and json results from a previous action.

Action Results

  • Script Result
    Script Result NameValue optionsExample
    ScriptResultTrue/FalseTrue
  • JSON Result
    {
    "entity_insight" : "<div class="dmarc-compliance"> <table width="100%"> <col style="width:20%"><col style="width:80%"> <tr> <td><img title="compliant" src="" width="17" /></td> <td>DMARC Compliant</td> </tr> <tr> <td><img title="spf_align" src="" width="17" /></td> <td>SPF Alignment</td> </tr> <tr> <td><img title="spf_auth" src="" width="17" /></td> <td>SPF Authenticated</td> </tr> <tr> <td><img title="spf_auth" src="" width="17" /></td> <td>Strong SPF Record</td> </tr> <tr> <td><img title="dkim_align" src="" width="17" /></td> <td>DKIM Alignment</td> </tr> <tr> <td><img title="dkim_align" src="" width="17" /></td> <td>ARC Verify</td> </tr> </table> </div>",
    "template" : "{%- set ok_img = "" -%} {%- set fail_img = "" -%} <div class="dmarc-compliance"> <table width="100%"> <col style="width:20%"><col style="width:80%"> <tr> <td> {%- if DMARC -%} {%- if DMARC['valid'] -%} <img title="compliant" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="compliant" src="{{ fail_img }}" width="17" /> {%- endif -%} {%- else -%} <img title="compliant" src="{{ fail_img }}" width="17" /> {%- endif -%} </td> <td>DMARC Compliant</td> </tr> <tr> <td> {%- if 'tags' in DMARC and DMARC['tags']['aspf'] == "r" -%} {%- if FromDomain == MFromDomain or FromParentDomain == MFromDomain -%} <img title="spf_align" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="spf_align" src="{{ fail_img }}" width="17" /> {%- endif -%} {%- else -%} {%- if FromDomain == MFromDomain -%} <img title="spf_align" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="spf_align" src="{{ fail_img }}" width="17" /> {%- endif -%} {%- endif -%} </td> <td>SPF Alignment</td> </tr> <tr> <td> {%- if SPF -%} {%- if SPF['Auth'] == True -%} <img title="spf_auth" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="spf_auth" src="{{ fail_img}}" width="17" /> {%- endif -%} {%- else -%} <img title="spf_auth" src="{{ fail_img}}" width="17" /> {%- endif -%} </td> <td>SPF Authenticated</td> </tr> <tr> <td> {%- if StrongSPF == True -%} <img title="spf_auth" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="spf_auth" src="{{ fail_img}}" width="17" /> {%- endif -%} </td> <td>Strong SPF Record</td> </tr> <tr> <td> {%- if DKIMVerify == True -%} <img title="dkim_align" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="dkim_align" src="{{ fail_img }}" width="17" /> {%- endif -%} </td> <td>DKIM Alignment</td> </tr> <tr> <td> {%- if ARCVerify -%} {%- if ARCVerify[result] == True -%} <img title="dkim_align" src="{{ ok_img }}" width="17" /> {%- else -%} <img title="dkim_align" src="{{ fail_img }}" width="17" /> {%- endif -%} {% else %} <img title="dkim_align" src="{{ fail_img }}" width="17" /> {%- endif -%} </td> <td>ARC Verify</td> </tr> </table> </div>"
    }

Render Template

Description

Renders a Jinja2 template using a JSON input.

Parameters

ParameterTypeDefault ValueIs MandatoryDescription
JSON ObjectJSONN/ANoSpecify the raw JSON object that will be used to render the template. This value is available as the variable input_json in the jinja template.

{“input_json”: {“Entity” : “0.0.0.0”}}

JinjaDropdownJSONNoSpecify the Jinja template code to be rendered. It will override the template parameter. Append |safe to disable HTML encoding.
Include Case DataCheckboxUncheckedNoIf enabled, entity attributes and event data are available in the variables input_json[“SecurityEvents”] and input_json[“SecuritEntities”].
TemplateHTMLEmail HTML TemplateNoSpecify the Jinja2 Template to display. It can be a HTML template from “Settings->environment” or added in the content box.

Example

In this scenario, we’re passing a JSON result from VirusTotal from a previous action and returning entity value.

Action Results

  • Script Result
    Script Result NameValue optionsExample
    ScriptResultOutput ResultEntity: 0.0.0.26

    Render Template from Array

    Description

    Render Template, but for lists. Loops through a list and applies the Jinja template to each list item.

    Parameters

    ParameterTypeDefault ValueIs MandatoryDescription
    Array InputArray[]NoPoint to output from a previous Action that outputs an Array.

    [“10.10.10.10”]

    JinjaDropdownHTMLNoThe Jinja template code to render. Will override Template parameters. Append | safe to disable HTML encoding.
    JoinString,NoJOIN character between loops to join together.
    PrefixStringN/ANoPrefix string before output.
    SuffixStringN/ANoSuffix string after output.

    Example

    In this scenario, we’re parsing a list of JSONs and returning IP addresses joined by a comma.

    Action Results

    • Script Result
      Script Result NameValue optionsExample
      ScriptResultOutput Result0.0.0.0,0.0.0.1