diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 0104e80d45ef8..7895eb1794db4 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -306,6 +306,11 @@ datadog_checks_base/datadog_checks/base/checks/windows/ @DataDog/wi /mux/manifest.json @DataDog/saas-integrations @DataDog/documentation /mux/metadata.csv @DataDog/saas-integrations @DataDog/documentation +/okta_workflows/ @DataDog/saas-integrations +/okta_workflows/*.md @DataDog/saas-integrations @DataDog/documentation +/okta_workflows/manifest.json @DataDog/saas-integrations @DataDog/documentation +/okta_workflows/assets/logs/ @DataDog/saas-integrations @DataDog/documentation @DataDog/logs-backend @DataDog/logs-core + /palo_alto_cortex_xdr/ @DataDog/saas-integrations /palo_alto_cortex_xdr/*.md @DataDog/saas-integrations @DataDog/documentation /palo_alto_cortex_xdr/manifest.json @DataDog/saas-integrations @DataDog/documentation diff --git a/.github/workflows/config/labeler.yml b/.github/workflows/config/labeler.yml index 420482ad42152..c3eddd321c36a 100644 --- a/.github/workflows/config/labeler.yml +++ b/.github/workflows/config/labeler.yml @@ -379,6 +379,8 @@ integration/nvidia_triton: - nvidia_triton/**/* integration/oke: - oke/**/* +integration/okta_workflows: +- okta_workflows/**/* integration/oom_kill: - oom_kill/**/* integration/openai: diff --git a/okta_workflows/CHANGELOG.md b/okta_workflows/CHANGELOG.md new file mode 100644 index 0000000000000..84c6911a1328a --- /dev/null +++ b/okta_workflows/CHANGELOG.md @@ -0,0 +1,8 @@ +# CHANGELOG - okta_workflows + +## 1.0.0 / 2024-12-23 + +***Added***: + +* Initial Release + diff --git a/okta_workflows/README.md b/okta_workflows/README.md new file mode 100644 index 0000000000000..35775ca86c318 --- /dev/null +++ b/okta_workflows/README.md @@ -0,0 +1,53 @@ +# Okta Workflows + +## Overview +[Okta Workflows][1] is a no-code automation platform provided by Okta, designed to simplify and automate identity-related tasks and processes. It allows organizations to build custom workflows that integrate seamlessly with Okta's identity and access management capabilities and third-party applications, enhancing operational efficiency, security, and user experience. + +The Okta Workflows integration collects Okta workflow event logs and sends them to Datadog for comprehensive analysis. + +## Setup + +### Generate API Credentials in Okta Workflows +1. Log in to the [Okta Admin Console][2] as an **admin** which has the [Read-only administrators][3] role. +2. Follow the steps in [this guide][5] to generate an API token. + +### Get Okta Workflows Domain +1. Sign in to your Okta organization with your administrator account. +2. Locate the **Domain** by clicking your username in the top-right corner of the Admin Console. The domain appears in the dropdown menu. Your Okta domain looks like + - example.oktapreview.com + - example.okta.com + - example.okta-emea.com + +### Connect your Okta Workflows Account to Datadog +1. Add your API Token and Okta Domain + + | Parameters | Description | + |--------------------- |-----------------------------------| + | API Token | The API Key of Okta Workflows. | + | Okta Domain | The Domain of Okta Workflows. | + +2. Click the Save button to save your settings. + +## Data Collected + +### Logs + +The Okta Workflows integration collects and forwards Okta workflow event logs to Datadog. + +### Metrics + +The Okta Workflows integration does not collect any metrics. + +### Events + +The Okta Workflows integration does not include any events. + +## Support + +For further assistance, contact [Datadog Support][3]. + +[1]: https://www.okta.com/products/workflows/ +[2]: https://login.okta.com/ +[3]: https://help.okta.com/en-us/content/topics/security/administrators-read-only-admin.htm +[4]: https://docs.datadoghq.com/help/ +[5]: https://help.okta.com/en-us/content/topics/security/api.htm?cshid=ext-create-api-token#create-okta-api-token \ No newline at end of file diff --git a/okta_workflows/assets/dashboards/okta_workflows.json b/okta_workflows/assets/dashboards/okta_workflows.json new file mode 100644 index 0000000000000..2eba603ca4bb6 --- /dev/null +++ b/okta_workflows/assets/dashboards/okta_workflows.json @@ -0,0 +1,2714 @@ +{ + "title": "Okta Workflows", + "description": "The Okta Workflows dashboard offers a detailed overview of workflow activities, including trends, and event tracking for flows, connectors, folders, and tables. It highlights key insights like workflow success rates, and execution history, providing a centralized view of workflow operations and user actions.", + "widgets": [ + { + "id": 7612801639546888, + "definition": { + "type": "image", + "url": "", + "sizing": "contain", + "has_background": true, + "has_border": true, + "vertical_align": "center", + "horizontal_align": "center" + }, + "layout": { + "x": 0, + "y": 0, + "width": 6, + "height": 2 + } + }, + { + "id": 5159039009035336, + "definition": { + "title": "Monitors Summary", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 5841197223063948, + "definition": { + "title": "Monitors Summary", + "type": "manage_status", + "display_format": "countsAndList", + "color_preference": "text", + "hide_zero_counts": true, + "show_status": true, + "last_triggered_format": "relative", + "query": "tag:(integration:okta-workflows)", + "sort": "status,asc", + "count": 50, + "start": 0, + "summary_type": "monitors", + "show_priority": false, + "show_last_triggered": false + }, + "layout": { + "x": 0, + "y": 0, + "width": 6, + "height": 5 + } + } + ] + }, + "layout": { + "x": 6, + "y": 0, + "width": 6, + "height": 6 + } + }, + { + "id": 691608206884740, + "definition": { + "type": "note", + "content": "**Overview**\n\nThe Okta Workflows dashboard offers a detailed overview of workflow activities, including trends, and event tracking for flows, connectors, folders, and tables. It highlights key insights like workflow success rates, and execution history, providing a centralized view of workflow operations and user actions.\n\nFor more information, see the [Okta Workflows Integration Documentation](https://docs.datadoghq.com/integrations/okta-workflows/).\n\n**Tips**\n- Use the timeframe selector in the top right of the dashboard to change the default timeframe.\n- Clone this dashboard to rearrange, modify and add widgets and visualizations.", + "background_color": "white", + "font_size": "14", + "text_align": "left", + "vertical_align": "top", + "show_tick": false, + "tick_pos": "50%", + "tick_edge": "left", + "has_padding": true + }, + "layout": { + "x": 0, + "y": 2, + "width": 6, + "height": 4 + } + }, + { + "id": 1490333542954818, + "definition": { + "title": "Workflows Overview", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 37978737945836, + "definition": { + "title": "Success Rate of Workflow Events", + "title_size": "16", + "title_align": "left", + "type": "query_value", + "requests": [ + { + "formulas": [ + { + "number_format": { + "unit": { + "label": "%", + "type": "custom_unit_label" + } + }, + "formula": "query2 / query1 * 100" + } + ], + "conditional_formats": [ + { + "comparator": ">", + "palette": "white_on_green", + "value": 95 + }, + { + "comparator": ">", + "palette": "black_on_light_green", + "value": 90 + }, + { + "comparator": ">", + "palette": "green_on_white", + "value": 80 + }, + { + "comparator": ">", + "palette": "white_on_yellow", + "value": 70 + }, + { + "comparator": "<=", + "palette": "white_on_red", + "value": 70 + } + ], + "response_format": "scalar", + "queries": [ + { + "name": "query2", + "data_source": "logs", + "search": { + "query": "source:okta-workflows -@evt.outcome:(FAILURE OR failure) $Workflow_Name $User_Name $User_ID $User_Email" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "count", + "metric": "@log.uuid", + "interval": 300000 + }, + "storage": "hot" + }, + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows $Workflow_Name $User_Name $User_ID $User_Email" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "count", + "metric": "@log.uuid", + "interval": 300000 + }, + "storage": "hot" + } + ] + } + ], + "autoscale": true, + "precision": 2 + }, + "layout": { + "x": 0, + "y": 0, + "width": 3, + "height": 3 + } + }, + { + "id": 3352439277636610, + "definition": { + "title": "Workflow Events over Time", + "title_size": "16", + "title_align": "left", + "show_legend": true, + "legend_layout": "auto", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "alias": "Workflow Events", + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "line" + } + ] + }, + "layout": { + "x": 3, + "y": 0, + "width": 9, + "height": 3 + } + }, + { + "id": 1874939174648428, + "definition": { + "title": "Frequent Workflow Events", + "title_size": "16", + "title_align": "left", + "type": "toplist", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@evt.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "style": { + "display": { + "type": "stacked", + "legend": "automatic" + } + } + }, + "layout": { + "x": 0, + "y": 3, + "width": 6, + "height": 4 + } + }, + { + "id": 8441169342368060, + "definition": { + "title": "Infrequent Workflow Events", + "title_size": "16", + "title_align": "left", + "type": "toplist", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@evt.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "asc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "asc" + } + ] + } + } + ], + "style": { + "display": { + "type": "stacked", + "legend": "automatic" + } + } + }, + "layout": { + "x": 6, + "y": 3, + "width": 6, + "height": 4 + } + }, + { + "id": 4834793462373932, + "definition": { + "title": "Workflow Events by Location", + "title_size": "16", + "title_align": "left", + "type": "geomap", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@network.client.geoip.country.iso_code", + "limit": 250, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "sort": { + "count": 250, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "style": { + "palette": "hostmap_blues", + "palette_flip": false + }, + "view": { + "focus": "WORLD" + } + }, + "layout": { + "x": 0, + "y": 7, + "width": 12, + "height": 4 + } + } + ] + }, + "layout": { + "x": 0, + "y": 6, + "width": 12, + "height": 12 + } + }, + { + "id": 5158160747359662, + "definition": { + "title": "Flows Insights", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 8524190436046540, + "definition": { + "title": "Created Flows by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.create $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@enrichment_details.workflow_id" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@enrichment_details.workflow_id" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 146472154927972, + "definition": { + "title": "Deleted Flows by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@enrichment_details.workflow_id" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@enrichment_details.workflow_id" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 8558335725079792, + "definition": { + "title": "Created and Deleted Flows over Time", + "title_size": "16", + "title_align": "left", + "show_legend": true, + "legend_layout": "auto", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "alias": "Created Flows", + "formula": "query1" + }, + { + "alias": "Deleted Flows", + "formula": "query2" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.create $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@enrichment_details.workflow_id" + }, + "storage": "hot" + }, + { + "name": "query2", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@enrichment_details.workflow_id" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "bars" + } + ] + }, + "layout": { + "x": 0, + "y": 4, + "width": 12, + "height": 4 + } + }, + { + "id": 5027090578075560, + "definition": { + "title": "Activated Flows by User", + "title_size": "16", + "title_align": "left", + "type": "query_table", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.activate $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + }, + { + "facet": "@enrichment_details.workflow_name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "sort": { + "count": 100, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + }, + "formulas": [ + { + "cell_display_mode": "bar", + "alias": "Count", + "formula": "query1", + "conditional_formats": [ + { + "comparator": ">=", + "value": 0, + "palette": "black_on_light_green" + } + ] + } + ] + } + ], + "has_search_bar": "auto" + }, + "layout": { + "x": 0, + "y": 8, + "width": 6, + "height": 4 + } + }, + { + "id": 7077499463331688, + "definition": { + "title": "Deactivated Flows by User", + "title_size": "16", + "title_align": "left", + "type": "query_table", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.deactivate $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + }, + { + "facet": "@enrichment_details.workflow_name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "sort": { + "count": 100, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + }, + "formulas": [ + { + "cell_display_mode": "bar", + "alias": "Count", + "formula": "query1", + "conditional_formats": [ + { + "comparator": ">=", + "value": 0, + "palette": "black_on_light_red" + } + ] + } + ] + } + ], + "has_search_bar": "auto" + }, + "layout": { + "x": 6, + "y": 8, + "width": 6, + "height": 4 + } + }, + { + "id": 281779904992220, + "definition": { + "title": "Activated and Deactivated Flows Trend", + "title_size": "16", + "title_align": "left", + "show_legend": true, + "legend_layout": "auto", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "alias": "Activated Flows", + "formula": "query1" + }, + { + "alias": "Deactivated Flows", + "formula": "query2" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.activate $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query2", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.deactivate $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "bars" + } + ] + }, + "layout": { + "x": 0, + "y": 12, + "width": 12, + "height": 4 + } + }, + { + "id": 6252417277995878, + "definition": { + "title": "Exported Flows by User", + "title_size": "16", + "title_align": "left", + "type": "query_table", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.export $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + }, + { + "facet": "@enrichment_details.workflow_name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "sort": { + "count": 100, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + }, + "formulas": [ + { + "cell_display_mode": "bar", + "alias": "Count", + "formula": "query1" + } + ] + } + ], + "has_search_bar": "auto" + }, + "layout": { + "x": 0, + "y": 16, + "width": 6, + "height": 4 + } + }, + { + "id": 6336040166464990, + "definition": { + "title": "Imported Flows by User", + "title_size": "16", + "title_align": "left", + "type": "query_table", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.import $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + }, + { + "facet": "@enrichment_details.workflow_name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "sort": { + "count": 100, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + }, + "formulas": [ + { + "cell_display_mode": "bar", + "alias": "Count", + "formula": "query1" + } + ] + } + ], + "has_search_bar": "auto" + }, + "layout": { + "x": 6, + "y": 16, + "width": 6, + "height": 4 + } + }, + { + "id": 6367758736022530, + "definition": { + "title": "Canceled Flow Executions by User", + "title_size": "16", + "title_align": "left", + "type": "query_table", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.execution.cancel $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + }, + { + "facet": "@enrichment_details.workflow_name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "sort": { + "count": 100, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + }, + "formulas": [ + { + "conditional_formats": [ + { + "comparator": ">=", + "value": 0, + "palette": "black_on_light_red" + } + ], + "cell_display_mode": "bar", + "alias": "Count", + "formula": "query1" + } + ] + } + ], + "has_search_bar": "auto" + }, + "layout": { + "x": 0, + "y": 20, + "width": 12, + "height": 3 + } + } + ] + }, + "layout": { + "x": 0, + "y": 18, + "width": 12, + "height": 24 + } + }, + { + "id": 116212910186676, + "definition": { + "title": "Execution History and Workflow Runs", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 1503019260849880, + "definition": { + "title": "Activated and Deactivated Execution History Trend", + "title_size": "16", + "title_align": "left", + "show_legend": true, + "legend_layout": "horizontal", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "alias": "Activated Execution History", + "formula": "query1" + }, + { + "alias": "Deactivated Execution History", + "formula": "query2" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.execution_history.activate $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query2", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.execution_history.deactivate $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "line" + } + ] + }, + "layout": { + "x": 0, + "y": 0, + "width": 12, + "height": 4 + } + }, + { + "id": 8460370647242532, + "definition": { + "title": "Flow Execution History Deletion by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.flow.execution_history.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 4, + "width": 6, + "height": 4 + } + }, + { + "id": 7044391512767462, + "definition": { + "title": "Delegated Workflow Runs by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.delegatedflow.run $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 4, + "width": 6, + "height": 4 + } + }, + { + "id": 2519489860872178, + "definition": { + "title": "Top Delegated Workflow Runs", + "title_size": "16", + "title_align": "left", + "type": "toplist", + "requests": [ + { + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.delegatedflow.run $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@enrichment_details.workflow_name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + } + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "style": { + "display": { + "type": "stacked", + "legend": "automatic" + }, + "palette": "datadog16" + } + }, + "layout": { + "x": 0, + "y": 8, + "width": 4, + "height": 4 + } + }, + { + "id": 1396310714058086, + "definition": { + "title": "Delegated Workflow Runs over Time", + "title_size": "16", + "title_align": "left", + "show_legend": false, + "legend_layout": "auto", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.delegatedflow.run $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "line" + } + ] + }, + "layout": { + "x": 4, + "y": 8, + "width": 8, + "height": 4 + } + } + ] + }, + "layout": { + "x": 0, + "y": 42, + "width": 12, + "height": 13, + "is_column_break": true + } + }, + { + "id": 7914967042765606, + "definition": { + "title": "Workflow Connectors Insights", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 7817798015265170, + "definition": { + "title": "Workflow Connectors Creation by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.connection.create $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 974276237318820, + "definition": { + "title": "Workflow Connectors Deletion by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.connection.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 6147995091131244, + "definition": { + "title": "Workflow Connectors Activity Trend", + "title_size": "16", + "title_align": "left", + "show_legend": true, + "legend_layout": "auto", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "alias": "Create", + "formula": "query1" + }, + { + "alias": "Delete", + "formula": "query2" + }, + { + "alias": "Reauthorize", + "formula": "query3" + }, + { + "alias": "Revoke", + "formula": "query4" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.connection.create $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query2", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.connection.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query3", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.connection.reauthorize $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query4", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.connection.revoke $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "line" + } + ] + }, + "layout": { + "x": 0, + "y": 4, + "width": 12, + "height": 4 + } + } + ] + }, + "layout": { + "x": 0, + "y": 55, + "width": 12, + "height": 9 + } + }, + { + "id": 530845092314274, + "definition": { + "title": "Folders", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 8729663989628246, + "definition": { + "title": "Folders Created by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.folder.create $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 3931706691014624, + "definition": { + "title": "Folders Deleted by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.folder.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 5323841840937246, + "definition": { + "title": "Folders Exported by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.folder.export $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 500, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 4, + "width": 6, + "height": 4 + } + }, + { + "id": 304742592564742, + "definition": { + "title": "Folders Imported by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.folder.import $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "scalar", + "sort": { + "count": 500, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + }, + "style": { + "palette": "datadog16" + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 4, + "width": 6, + "height": 4 + } + } + ] + }, + "layout": { + "x": 0, + "y": 64, + "width": 12, + "height": 9 + } + }, + { + "id": 5969708596634978, + "definition": { + "title": "Tables", + "background_color": "vivid_blue", + "show_title": true, + "type": "group", + "layout_type": "ordered", + "widgets": [ + { + "id": 6908673875560986, + "definition": { + "title": "Tables Created by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.table.create $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 7839173854742012, + "definition": { + "title": "Tables Deleted by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.table.delete $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 0, + "width": 6, + "height": 4 + } + }, + { + "id": 8394705923034074, + "definition": { + "title": "Tables Updated by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.table.update $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 4, + "width": 12, + "height": 4 + } + }, + { + "id": 1734222538772660, + "definition": { + "title": "Tables Exported by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.table.export $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 0, + "y": 8, + "width": 6, + "height": 4 + } + }, + { + "id": 2009795827136474, + "definition": { + "title": "Tables Imported by User", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "scalar", + "formulas": [ + { + "formula": "query1" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.table.import $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [ + { + "facet": "@usr.name", + "limit": 10, + "sort": { + "aggregation": "cardinality", + "order": "desc", + "metric": "@log.uuid" + }, + "should_exclude_missing": true + } + ], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "style": { + "palette": "datadog16" + }, + "sort": { + "count": 10, + "order_by": [ + { + "type": "formula", + "index": 0, + "order": "desc" + } + ] + } + } + ], + "type": "sunburst", + "legend": { + "type": "table" + } + }, + "layout": { + "x": 6, + "y": 8, + "width": 6, + "height": 4 + } + } + ] + }, + "layout": { + "x": 0, + "y": 73, + "width": 12, + "height": 13 + } + }, + { + "id": 4583199094802920, + "definition": { + "title": "Role Activities over Time", + "title_size": "16", + "title_align": "left", + "show_legend": true, + "legend_layout": "auto", + "legend_columns": [ + "avg", + "min", + "max", + "value", + "sum" + ], + "type": "timeseries", + "requests": [ + { + "formulas": [ + { + "alias": "Group Added", + "formula": "query1" + }, + { + "alias": "Group Removed", + "formula": "query2" + }, + { + "alias": "User Added", + "formula": "query3" + }, + { + "alias": "User Removed", + "formula": "query4" + } + ], + "queries": [ + { + "name": "query1", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.role.group.add $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query2", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.role.group.remove $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query3", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.role.user.add $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + }, + { + "name": "query4", + "data_source": "logs", + "search": { + "query": "source:okta-workflows service:workflows @evt.name:workflows.user.role.user.remove $User_Name $User_ID $User_Email $Workflow_Name" + }, + "indexes": [ + "*" + ], + "group_by": [], + "compute": { + "aggregation": "cardinality", + "metric": "@log.uuid" + }, + "storage": "hot" + } + ], + "response_format": "timeseries", + "style": { + "palette": "dog_classic", + "order_by": "values", + "line_type": "solid", + "line_width": "normal" + }, + "display_type": "line" + } + ] + }, + "layout": { + "x": 0, + "y": 0, + "width": 12, + "height": 4 + } + }, + { + "id": 5396925856410067, + "definition": { + "title": "Workflow Event Logs", + "title_size": "16", + "title_align": "left", + "requests": [ + { + "response_format": "event_list", + "query": { + "data_source": "logs_stream", + "query_string": "source:okta-workflows service:workflows $User_Name $User_ID $User_Email $Workflow_Name", + "indexes": [], + "storage": "hot", + "sort": { + "order": "desc", + "column": "timestamp" + } + }, + "columns": [ + { + "field": "status_line", + "width": "auto" + }, + { + "field": "timestamp", + "width": "auto" + }, + { + "field": "service", + "width": "auto" + }, + { + "field": "@usr.name", + "width": "auto" + }, + { + "field": "@usr.email", + "width": "auto" + }, + { + "field": "content", + "width": "auto" + } + ] + } + ], + "type": "list_stream" + }, + "layout": { + "x": 0, + "y": 4, + "width": 12, + "height": 3 + } + } + ], + "template_variables": [ + { + "name": "User_Name", + "prefix": "@usr.name", + "available_values": [], + "default": "*" + }, + { + "name": "User_ID", + "prefix": "@usr.id", + "available_values": [], + "default": "*" + }, + { + "name": "User_Email", + "prefix": "@usr.email", + "available_values": [], + "default": "*" + }, + { + "name": "Workflow_Name", + "prefix": "@enrichment_details.workflow_name", + "available_values": [], + "default": "*" + } + ], + "layout_type": "ordered", + "notify_list": [], + "reflow_type": "fixed" +} \ No newline at end of file diff --git a/okta_workflows/assets/logs/okta-workflows.yaml b/okta_workflows/assets/logs/okta-workflows.yaml new file mode 100644 index 0000000000000..c6420d2f9c1bf --- /dev/null +++ b/okta_workflows/assets/logs/okta-workflows.yaml @@ -0,0 +1,227 @@ +id: okta-workflows +metric_id: okta-workflows +backend_only: false +facets: + - groups: + - Event + name: Event Name + path: evt.name + source: log + - groups: + - Event + name: Event Outcome + path: evt.outcome + source: log + - groups: + - Web Access + name: User-Agent + path: http.useragent + source: log + - groups: + - Web Access + name: Browser + path: http.useragent_details.browser.family + source: log + - groups: + - Web Access + name: Device + path: http.useragent_details.device.family + source: log + - groups: + - Web Access + name: OS + path: http.useragent_details.os.family + source: log + - groups: + - Geoip + name: City Name + path: network.client.geoip.city.name + source: log + - groups: + - Geoip + name: Continent Code + path: network.client.geoip.continent.code + source: log + - groups: + - Geoip + name: Continent Name + path: network.client.geoip.continent.name + source: log + - groups: + - Geoip + name: Country ISO Code + path: network.client.geoip.country.iso_code + source: log + - groups: + - Geoip + name: Country Name + path: network.client.geoip.country.name + source: log + - groups: + - Geoip + name: Subdivision ISO Code + path: network.client.geoip.subdivision.iso_code + source: log + - groups: + - Geoip + name: Subdivision Name + path: network.client.geoip.subdivision.name + source: log + - groups: + - Web Access + name: Client IP + path: network.client.ip + source: log + - groups: + - User + name: User Email + path: usr.email + source: log + - groups: + - User + name: User ID + path: usr.id + source: log + - groups: + - User + name: User Name + path: usr.name + source: log + - groups: + - Geoip + name: AS Domain + path: network.client.geoip.as.domain + source: log +pipeline: + type: pipeline + name: Okta Workflows + enabled: true + filter: + query: source:okta-workflows + processors: + - type: service-remapper + name: Define `service` as the official service of the log + enabled: true + sources: + - service + - type: date-remapper + name: Define `log.published` as the official date of the log + enabled: true + sources: + - log.published + - type: message-remapper + name: Define `log.displayMessage` as the official message of the log + enabled: true + sources: + - log.displayMessage + - type: status-remapper + name: Define `log.severity` as the official status of the log + enabled: true + sources: + - log.severity + - type: attribute-remapper + name: Map `log.eventType` to `evt.name` + enabled: true + sources: + - log.eventType + sourceType: attribute + target: evt.name + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.outcome.result` to `evt.outcome` + enabled: true + sources: + - log.outcome.result + sourceType: attribute + target: evt.outcome + targetType: attribute + targetFormat: string + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.client.userAgent.rawUserAgent` to `http.useragent` + enabled: true + sources: + - log.client.userAgent.rawUserAgent + sourceType: attribute + target: http.useragent + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: user-agent-parser + name: User-Agent Parser for `http.useragent` + enabled: true + sources: + - http.useragent + target: http.useragent_details + encoded: false + combineVersionDetails: false + - type: attribute-remapper + name: Map `log.actor.id` to `usr.id` + enabled: true + sources: + - log.actor.id + sourceType: attribute + target: usr.id + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.actor.alternateId` to `usr.email` + enabled: true + sources: + - log.actor.alternateId + sourceType: attribute + target: usr.email + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.actor.displayName` to `usr.name` + enabled: true + sources: + - log.actor.displayName + sourceType: attribute + target: usr.name + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.actor.type` to `usr.type` + enabled: true + sources: + - log.actor.type + sourceType: attribute + target: usr.type + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.actor.detailEntry` to `usr.details` + enabled: true + sources: + - log.actor.detailEntry + sourceType: attribute + target: usr.details + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: attribute-remapper + name: Map `log.client.ipAddress` to `network.client.ip` + enabled: true + sources: + - log.client.ipAddress + sourceType: attribute + target: network.client.ip + targetType: attribute + preserveSource: false + overrideOnConflict: false + - type: geo-ip-parser + name: GeoIP for the `network.client.ip` + enabled: true + sources: + - network.client.ip + target: network.client.geoip + ip_processing_behavior: do-nothing diff --git a/okta_workflows/assets/logs/okta-workflows_tests.yaml b/okta_workflows/assets/logs/okta-workflows_tests.yaml new file mode 100644 index 0000000000000..ebbcfcc13c61a --- /dev/null +++ b/okta_workflows/assets/logs/okta-workflows_tests.yaml @@ -0,0 +1,149 @@ +id: "okta-workflows" +tests: + - + sample: |- + { + "enrichment_details" : { + "workflow_id" : "01JDNV8HCJPX0JR7JSR9JY5CA5", + "workflow_name" : "Schedule Flow" + }, + "log" : { + "severity" : "INFO", + "request" : { + "ipChain" : [ { + "ip" : "null" + } ] + }, + "eventType" : "workflows.user.flow.activate", + "published" : "2024-12-23T09:01:06.674Z", + "uuid" : "726d2b15-c10c-11ef-b07f-8d23c9fdf856", + "version" : "0", + "target" : [ { + "alternateId" : "Okta Workflows", + "displayName" : "Okta Workflows", + "id" : "00olyc3jhdlie0qFu697", + "type" : "AppInstance" + }, { + "alternateId" : "Schedule Flow", + "displayName" : "Schedule Flow", + "id" : "01JDNV8HCJPX0JR7JSR9JY5CA5", + "type" : "Flow" + } ], + "actor" : { + "alternateId" : "fejehi2728@kazvi.com", + "displayName" : "Dhruva Patel", + "id" : "00ulycdpfr62PfUc6697", + "type" : "User" + }, + "debugContext" : { + "debugData" : { + "sessionId" : "451605df-f773-4c06-933f-fc471a3069b4" + } + }, + "displayMessage" : "Flow activated", + "client" : { + "zone" : "null", + "ipAddress" : "103.108.207.58", + "userAgent" : { + "os" : "Windows 10", + "browser" : "CHROME", + "rawUserAgent" : "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36" + }, + "device" : "Computer", + "geographicalContext" : { + "country" : "India", + "city" : "Bharūch", + "postalCode" : "392012", + "state" : "Gujarat", + "geolocation" : { + "lon" : 72.9782, + "lat" : 21.7003 + } + } + }, + "outcome" : { + "result" : "SUCCESS" + }, + "transaction" : { + "id" : "451605df-f773-4c06-933f-fc471a3069b4", + "type" : "WORKFLOW" + } + } + } + result: + custom: + enrichment_details: + workflow_id: "01JDNV8HCJPX0JR7JSR9JY5CA5" + workflow_name: "Schedule Flow" + evt: + name: "workflows.user.flow.activate" + outcome: "SUCCESS" + http: + useragent: "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36" + useragent_details: + browser: + family: "Chrome" + major: "131" + minor: "0" + patch: "0" + patch_minor: "0" + device: + category: "Desktop" + family: "Other" + os: + family: "Windows" + major: "10" + log: + client: + device: "Computer" + geographicalContext: + city: "Bharūch" + country: "India" + geolocation: + lat: 21.7003 + lon: 72.9782 + postalCode: "392012" + state: "Gujarat" + userAgent: + browser: "CHROME" + os: "Windows 10" + zone: "null" + debugContext: + debugData: + sessionId: "451605df-f773-4c06-933f-fc471a3069b4" + published: "2024-12-23T09:01:06.674Z" + request: + ipChain: + - + ip: "null" + severity: "INFO" + target: + - + alternateId: "Okta Workflows" + displayName: "Okta Workflows" + id: "00olyc3jhdlie0qFu697" + type: "AppInstance" + - + alternateId: "Schedule Flow" + displayName: "Schedule Flow" + id: "01JDNV8HCJPX0JR7JSR9JY5CA5" + type: "Flow" + transaction: + id: "451605df-f773-4c06-933f-fc471a3069b4" + type: "WORKFLOW" + uuid: "726d2b15-c10c-11ef-b07f-8d23c9fdf856" + version: "0" + network: + client: + geoip: {} + ip: "103.108.207.58" + usr: + email: "fejehi2728@kazvi.com" + id: "00ulycdpfr62PfUc6697" + name: "Dhruva Patel" + type: "User" + message: "Flow activated" + status: "info" + tags: + - "source:LOGS_SOURCE" + timestamp: 1734944466674 \ No newline at end of file diff --git a/okta_workflows/assets/monitors/high_number_of_abandoned_outcome_events_detected.json b/okta_workflows/assets/monitors/high_number_of_abandoned_outcome_events_detected.json new file mode 100644 index 0000000000000..bd6b85e5569e4 --- /dev/null +++ b/okta_workflows/assets/monitors/high_number_of_abandoned_outcome_events_detected.json @@ -0,0 +1,35 @@ +{ + "version": 2, + "created_at": "2024-12-23", + "last_updated_at": "2024-12-23", + "title": "High Number of Abandoned Outcome Events Detected", + "description": "Abandoned outcome events in Okta Workflows occur when workflows start but remain incomplete due to misconfigurations or user disengagement. This monitor tracks these events to prevent inefficiencies, resource waste, and ensure reliable automation. Immediate action is needed to resolve issues.", + "definition": { + "id": 159650724, + "name": "High Number of Abandoned Outcome Events Detected", + "type": "log alert", + "query": "logs(\"source:okta-workflows service:workflows @evt.outcome:ABANDONED @evt.name:workflows.*\").index(\"*\").rollup(\"cardinality\", \"@log.uuid\").last(\"1h\") > 50", + "message": "{{#is_alert}}\nAbandoned outcome events in Okta Workflows, indicates that a significant number of workflows are being initiated but not completed due to misconfigured processes, or user disengagement. This impacts automation reliability and may waste system resources.\n\nHigh number of abandoned outcome events detected in Okta Workflows. Immediate action is needed to identify and address the underlying causes.\n{{/is_alert}}", + "tags": [ + "integration:okta-workflows" + ], + "options": { + "thresholds": { + "critical": 50 + }, + "enable_logs_sample": false, + "notify_audit": false, + "on_missing_data": "default", + "include_tags": true, + "groupby_simple_monitor": false, + "silenced": {} + }, + "priority": null, + "restriction_policy": { + "bindings": [] + } + }, + "tags": [ + "integration:okta-workflows" + ] +} \ No newline at end of file diff --git a/okta_workflows/assets/monitors/high_number_of_denied_outcome_events_detected.json b/okta_workflows/assets/monitors/high_number_of_denied_outcome_events_detected.json new file mode 100644 index 0000000000000..87795c4da969b --- /dev/null +++ b/okta_workflows/assets/monitors/high_number_of_denied_outcome_events_detected.json @@ -0,0 +1,35 @@ +{ + "version": 2, + "created_at": "2024-12-23", + "last_updated_at": "2024-12-23", + "title": "High Number of Denied Outcome Events Detected", + "description": "Denied outcome events in Okta Workflows show blocked or rejected requests, disrupting workflow execution and operations. This monitor tracks such events to identify issues and ensure smooth processes. Immediate action is advised to address the root cause.", + "definition": { + "id": 159650626, + "name": "High Number of Denied Outcome Events Detected", + "type": "log alert", + "query": "logs(\"source:okta-workflows service:workflows @evt.outcome:DENY @evt.name:workflows.*\").index(\"*\").rollup(\"cardinality\", \"@log.uuid\").last(\"1h\") > 50", + "message": "{{#is_alert}}\nDenied outcome events for Okta Workflows indicates that a large number of requests are being blocked or rejected. It impacts workflow execution, potentially leading to operational disruptions and access issues. \n\nHigh number of denied outcome events detected in Okta Workflows. Immediate investigation is recommended to identify the root cause and restore optimal workflow performance.\n{{/is_alert}}", + "tags": [ + "integration:okta-workflows" + ], + "options": { + "thresholds": { + "critical": 50 + }, + "enable_logs_sample": false, + "notify_audit": false, + "on_missing_data": "default", + "include_tags": true, + "groupby_simple_monitor": false, + "silenced": {} + }, + "priority": null, + "restriction_policy": { + "bindings": [] + } + }, + "tags": [ + "integration:okta-workflows" + ] +} \ No newline at end of file diff --git a/okta_workflows/assets/monitors/high_number_of_failure_outcome_events_detected.json b/okta_workflows/assets/monitors/high_number_of_failure_outcome_events_detected.json new file mode 100644 index 0000000000000..c342900758be1 --- /dev/null +++ b/okta_workflows/assets/monitors/high_number_of_failure_outcome_events_detected.json @@ -0,0 +1,35 @@ +{ + "version": 2, + "created_at": "2024-12-23", + "last_updated_at": "2024-12-23", + "title": "High Number of Failure Outcome Events Detected", + "description": "Failure outcome events in Okta Workflows indicate unsuccessful executions, causing delays and service interruptions. This monitor tracks such failures to ensure reliability and continuity. Immediate action is required to address issues and maintain smooth workflow performance.", + "definition": { + "id": 159649819, + "name": "High Number of Failure Outcome Events Detected", + "type": "log alert", + "query": "logs(\"source:okta-workflows service:workflows @evt.outcome:FAILURE @evt.name:workflows.*\").index(\"*\").rollup(\"cardinality\", \"@log.uuid\").last(\"1h\") > 50", + "message": "{{#is_alert}}\nFailure outcome events for Okta Workflows indicates unsuccessful workflow executions which leads to delays, operational inefficiencies, and potential service interruptions.\n\nHigh number of failure outcome events detected in Okta Workflows. Immediate action is needed to maintain reliability and operational continuity.\n{{/is_alert}}", + "tags": [ + "integration:okta-workflows" + ], + "options": { + "thresholds": { + "critical": 50 + }, + "enable_logs_sample": false, + "notify_audit": false, + "on_missing_data": "default", + "include_tags": true, + "groupby_simple_monitor": false, + "silenced": {} + }, + "priority": null, + "restriction_policy": { + "bindings": [] + } + }, + "tags": [ + "integration:okta-workflows" + ] +} \ No newline at end of file diff --git a/okta_workflows/assets/okta_workflows.svg b/okta_workflows/assets/okta_workflows.svg new file mode 100644 index 0000000000000..681c82cf0add6 --- /dev/null +++ b/okta_workflows/assets/okta_workflows.svg @@ -0,0 +1,52 @@ + + + + + + + + + + + + + + + + diff --git a/okta_workflows/assets/service_checks.json b/okta_workflows/assets/service_checks.json new file mode 100644 index 0000000000000..0637a088a01e8 --- /dev/null +++ b/okta_workflows/assets/service_checks.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/okta_workflows/images/okta_workflows_1.png b/okta_workflows/images/okta_workflows_1.png new file mode 100644 index 0000000000000..4de1ba5783ac6 Binary files /dev/null and b/okta_workflows/images/okta_workflows_1.png differ diff --git a/okta_workflows/images/okta_workflows_2.png b/okta_workflows/images/okta_workflows_2.png new file mode 100644 index 0000000000000..e51ed85e116cf Binary files /dev/null and b/okta_workflows/images/okta_workflows_2.png differ diff --git a/okta_workflows/manifest.json b/okta_workflows/manifest.json new file mode 100644 index 0000000000000..355ce05e05ae8 --- /dev/null +++ b/okta_workflows/manifest.json @@ -0,0 +1,65 @@ +{ + "manifest_version": "2.0.0", + "app_uuid": "e5e2a25d-aa66-41bc-9996-50f635dcc7a1", + "app_id": "okta-workflows", + "display_on_public_website": false, + "tile": { + "overview": "README.md#Overview", + "configuration": "README.md#Setup", + "support": "README.md#Support", + "changelog": "CHANGELOG.md", + "description": "Gain insights into Okta Workflows Events.", + "title": "Okta Workflows", + "media": [ + { + "caption": "Okta Workflows", + "image_url": "images/okta_workflows_1.png", + "media_type": "image" + }, + { + "caption": "Okta Workflows", + "image_url": "images/okta_workflows_2.png", + "media_type": "image" + } + ], + "classifier_tags": [ + "Category::Log Collection", + "Submitted Data Type::Logs", + "Offering::Integration", + "Category::Automation" + ] + }, + "assets": { + "integration": { + "auto_install": false, + "source_type_id": 33274584, + "source_type_name": "Okta Workflows", + "configuration": { + "spec": "assets/configuration/spec.yaml" + }, + "events": { + "creates_events": false + }, + "service_checks": { + "metadata_path": "assets/service_checks.json" + } + }, + "dashboards": { + "Okta Workflows": "assets/dashboards/okta_workflows.json" + }, + "monitors": { + "High Number of Abandoned Outcome Events Detected": "assets/monitors/high_number_of_abandoned_outcome_events_detected.json", + "High Number of Denied Outcome Events Detected": "assets/monitors/high_number_of_denied_outcome_events_detected.json", + "High Number of Failure Outcome Events Detected": "assets/monitors/high_number_of_failure_outcome_events_detected.json" + }, + "logs": { + "source": "okta-workflows" + } + }, + "author": { + "name": "Datadog", + "homepage": "https://www.datadoghq.com", + "sales_email": "info@datadoghq.com", + "support_email": "help@datadoghq.com" + } +}