diff --git a/.buildkite/ftr_security_serverless_configs.yml b/.buildkite/ftr_security_serverless_configs.yml
index cdb66caea4be7..6b1c222382687 100644
--- a/.buildkite/ftr_security_serverless_configs.yml
+++ b/.buildkite/ftr_security_serverless_configs.yml
@@ -106,6 +106,7 @@ enabled:
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/metadata/trial_license_complete_tier/configs/serverless.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/package/trial_license_complete_tier/configs/serverless.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy_response/trial_license_complete_tier/configs/serverless.config.ts
+ - x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/serverless.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/resolver/trial_license_complete_tier/configs/serverless.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/response_actions/trial_license_complete_tier/configs/serverless.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/spaces/trial_license_complete_tier/configs/serverless.config.ts
diff --git a/.buildkite/ftr_security_stateful_configs.yml b/.buildkite/ftr_security_stateful_configs.yml
index 8f780e081b11f..d3aadb1b7491d 100644
--- a/.buildkite/ftr_security_stateful_configs.yml
+++ b/.buildkite/ftr_security_stateful_configs.yml
@@ -93,6 +93,7 @@ enabled:
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/metadata/trial_license_complete_tier/configs/ess.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/package/trial_license_complete_tier/configs/ess.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy_response/trial_license_complete_tier/configs/ess.config.ts
+ - x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/ess.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/resolver/trial_license_complete_tier/configs/ess.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/response_actions/trial_license_complete_tier/configs/ess.config.ts
- x-pack/test/security_solution_api_integration/test_suites/edr_workflows/spaces/trial_license_complete_tier/configs/ess.config.ts
diff --git a/.buildkite/pipelines/security_solution_quality_gate/mki_quality_gate/mki_quality_gate_detection_engine.yml b/.buildkite/pipelines/security_solution_quality_gate/mki_quality_gate/mki_quality_gate_detection_engine.yml
index 8dd45a3d67306..023099dd99392 100644
--- a/.buildkite/pipelines/security_solution_quality_gate/mki_quality_gate/mki_quality_gate_detection_engine.yml
+++ b/.buildkite/pipelines/security_solution_quality_gate/mki_quality_gate/mki_quality_gate_detection_engine.yml
@@ -271,7 +271,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:esql:qa:serverless:release
+ - label: Running rule_execution_logic:esql:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:esql:qa:serverless:release
key: rule_execution_logic:esql:qa:serverless:release
agents:
@@ -285,7 +285,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:general_logic:qa:serverless:release
+ - label: Running rule_execution_logic:general_logic:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:general_logic:qa:serverless:release
key: rule_execution_logic:general_logic:qa:serverless:release
agents:
@@ -299,7 +299,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:indicator_match:qa:serverless:release
+ - label: Running rule_execution_logic:indicator_match:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:indicator_match:qa:serverless:release
key: rule_execution_logic:indicator_match:qa:serverless:release
agents:
@@ -313,7 +313,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:machine_learning:qa:serverless:release
+ - label: Running rule_execution_logic:machine_learning:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:machine_learning:qa:serverless:release
key: rule_execution_logic:machine_learning:qa:serverless:release
agents:
@@ -327,7 +327,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:new_terms:qa:serverless:release
+ - label: Running rule_execution_logic:new_terms:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:new_terms:qa:serverless:release
key: rule_execution_logic:new_terms:qa:serverless:release
agents:
@@ -341,7 +341,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:query:qa:serverless:release
+ - label: Running rule_execution_logic:query:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:query:qa:serverless:release
key: rule_execution_logic:query:qa:serverless:release
agents:
@@ -355,7 +355,7 @@ steps:
- exit_status: "1"
limit: 2
-- label: Running rule_execution_logic:threshold:qa:serverless:release
+ - label: Running rule_execution_logic:threshold:qa:serverless:release
command: .buildkite/scripts/pipelines/security_solution_quality_gate/api_integration/api-integration-tests.sh rule_execution_logic:threshold:qa:serverless:release
key: rule_execution_logic:threshold:qa:serverless:release
agents:
diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS
index cbf8505e0047a..10250b18541c8 100644
--- a/.github/CODEOWNERS
+++ b/.github/CODEOWNERS
@@ -1238,6 +1238,7 @@ x-pack/test_serverless/**/test_suites/observability/ai_assistant @elastic/obs-ai
/x-pack/test/accessibility/apps/group3/stack_monitoring.ts @elastic/stack-monitoring
# Fleet
+/x-pack/test/fleet_packages @elastic/fleet
/x-pack/test/fleet_api_integration @elastic/fleet
/x-pack/test/fleet_cypress @elastic/fleet
/x-pack/test/fleet_functional @elastic/fleet
@@ -1413,6 +1414,10 @@ x-pack/test/api_integration/deployment_agnostic/services/ @elastic/appex-qa
x-pack/test/**/deployment_agnostic/ @elastic/appex-qa #temporarily to monitor tests migration
# Core
+/test/plugin_functional/plugins/rendering_plugin @elastic/kibana-core
+/test/plugin_functional/plugins/session_notifications @elastic/kibana-core
+/x-pack/test/cloud_integration/plugins/saml_provider @elastic/kibana-core
+/x-pack/test/functional_embedded/plugins/iframe_embedded @elastic/kibana-core
/x-pack/test/functional/apps/saved_objects_management @elastic/kibana-core
/x-pack/test/usage_collection @elastic/kibana-core
/x-pack/test/licensing_plugin @elastic/kibana-core
@@ -1503,6 +1508,8 @@ x-pack/plugins/cloud_integrations/cloud_full_story/server/config.ts @elastic/kib
#CC# /x-pack/plugins/security/ @elastic/kibana-security
# Response Ops team
+/x-pack/test/examples/triggers_actions_ui_examples @elastic/response-ops
+/x-pack/test/functional_with_es_ssl/plugins/cases @elastic/response-ops
/x-pack/test/screenshot_creation/apps/response_ops_docs @elastic/response-ops
/x-pack/test/rule_registry @elastic/response-ops @elastic/obs-ux-management-team
/x-pack/test/accessibility/apps/group3/rules_connectors.ts @elastic/response-ops
@@ -1562,6 +1569,9 @@ x-pack/test/api_integration/apis/management/index_management/inference_endpoints
/x-pack/test/functional_search/ @elastic/search-kibana
# Management Experience - Deployment Management
+/x-pack/test/functional/apps/license_management @elastic/kibana-management
+/x-pack/test/functional/apps/painless_lab @elastic/kibana-management
+/x-pack/test/functional/apps/management @elastic/kibana-management
/x-pack/test/api_integration/services/index_management.ts @elastic/kibana-management
/x-pack/test/functional/services/grok_debugger.js @elastic/kibana-management
/x-pack/test/functional/apps/grok_debugger @elastic/kibana-management
@@ -1881,6 +1891,7 @@ x-pack/test/security_solution_cypress/cypress/tasks/expandable_flyout @elastic/
/x-pack/plugins/security_solution/public/common/components/threat_match @elastic/security-detection-engine
## Security Solution sub teams - security-defend-workflows
+/x-pack/test/defend_workflows_cypress @elastic/security-defend-workflows
/x-pack/test/api_integration/apis/osquery @elastic/security-defend-workflows
/x-pack/plugins/security_solution/public/management/ @elastic/security-defend-workflows
/x-pack/plugins/security_solution/public/common/lib/endpoint/ @elastic/security-defend-workflows
@@ -1983,6 +1994,7 @@ x-pack/plugins/security_solution/server/lib/security_integrations @elastic/secur
# Logstash
/x-pack/test/api_integration/apis/logstash @elastic/logstash
+/x-pack/test/functional/apps/logstash @elastic/logstash
#CC# /x-pack/plugins/logstash/ @elastic/logstash
# EUI team
@@ -2007,9 +2019,10 @@ x-pack/plugins/observability_solution/observability_shared/public/components/pro
/test/plugin_functional/plugins/eui_provider_dev_warning @elastic/appex-sharedux
/x-pack/test/banners_functional @elastic/appex-sharedux
/x-pack/test/custom_branding @elastic/appex-sharedux
-/x-pack/test/api_integration/apis/content_management @elastic/appex-sharedux
-/x-pack/test/accessibility/apps/group3/tags.ts @elastic/appex-sharedux
/x-pack/test/accessibility/apps/group3/snapshot_and_restore.ts @elastic/appex-sharedux
+/x-pack/test/accessibility/apps/group3/tags.ts @elastic/appex-sharedux
+/x-pack/test/api_integration/apis/content_management @elastic/appex-sharedux
+/x-pack/test/functional_solution_sidenav @elastic/appex-sharedux
/x-pack/test_serverless/functional/test_suites/common/spaces/spaces_selection.ts @elastic/appex-sharedux
/x-pack/test_serverless/functional/test_suites/common/spaces/index.ts @elastic/appex-sharedux
packages/react @elastic/appex-sharedux
diff --git a/api_docs/actions.mdx b/api_docs/actions.mdx
index 6a7dc9fd3750d..1db0e7083bdc4 100644
--- a/api_docs/actions.mdx
+++ b/api_docs/actions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/actions
title: "actions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the actions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'actions']
---
import actionsObj from './actions.devdocs.json';
diff --git a/api_docs/advanced_settings.mdx b/api_docs/advanced_settings.mdx
index ba989d5157352..64b36694e13b6 100644
--- a/api_docs/advanced_settings.mdx
+++ b/api_docs/advanced_settings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/advancedSettings
title: "advancedSettings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the advancedSettings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'advancedSettings']
---
import advancedSettingsObj from './advanced_settings.devdocs.json';
diff --git a/api_docs/ai_assistant_management_selection.mdx b/api_docs/ai_assistant_management_selection.mdx
index c74e6b9db82b1..33f787510f89a 100644
--- a/api_docs/ai_assistant_management_selection.mdx
+++ b/api_docs/ai_assistant_management_selection.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/aiAssistantManagementSelection
title: "aiAssistantManagementSelection"
image: https://source.unsplash.com/400x175/?github
description: API docs for the aiAssistantManagementSelection plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'aiAssistantManagementSelection']
---
import aiAssistantManagementSelectionObj from './ai_assistant_management_selection.devdocs.json';
diff --git a/api_docs/aiops.mdx b/api_docs/aiops.mdx
index afef817e1531e..ca23ed3fa827b 100644
--- a/api_docs/aiops.mdx
+++ b/api_docs/aiops.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/aiops
title: "aiops"
image: https://source.unsplash.com/400x175/?github
description: API docs for the aiops plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'aiops']
---
import aiopsObj from './aiops.devdocs.json';
diff --git a/api_docs/alerting.devdocs.json b/api_docs/alerting.devdocs.json
index 55610edc6e85a..e1d6edb818426 100644
--- a/api_docs/alerting.devdocs.json
+++ b/api_docs/alerting.devdocs.json
@@ -3763,10 +3763,6 @@
"deprecated": true,
"trackAdoption": false,
"references": [
- {
- "plugin": "ruleRegistry",
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts"
- },
{
"plugin": "ruleRegistry",
"path": "x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.ts"
diff --git a/api_docs/alerting.mdx b/api_docs/alerting.mdx
index 0148e0e6a3e4f..180086005cbaf 100644
--- a/api_docs/alerting.mdx
+++ b/api_docs/alerting.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/alerting
title: "alerting"
image: https://source.unsplash.com/400x175/?github
description: API docs for the alerting plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'alerting']
---
import alertingObj from './alerting.devdocs.json';
diff --git a/api_docs/apm.mdx b/api_docs/apm.mdx
index cf2cd66ae643c..8f84dcb7295f9 100644
--- a/api_docs/apm.mdx
+++ b/api_docs/apm.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/apm
title: "apm"
image: https://source.unsplash.com/400x175/?github
description: API docs for the apm plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'apm']
---
import apmObj from './apm.devdocs.json';
diff --git a/api_docs/apm_data_access.mdx b/api_docs/apm_data_access.mdx
index 1ad2d32097588..add4319eff127 100644
--- a/api_docs/apm_data_access.mdx
+++ b/api_docs/apm_data_access.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/apmDataAccess
title: "apmDataAccess"
image: https://source.unsplash.com/400x175/?github
description: API docs for the apmDataAccess plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'apmDataAccess']
---
import apmDataAccessObj from './apm_data_access.devdocs.json';
diff --git a/api_docs/banners.mdx b/api_docs/banners.mdx
index ab3b5df9e8703..1b481bf5ac5c4 100644
--- a/api_docs/banners.mdx
+++ b/api_docs/banners.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/banners
title: "banners"
image: https://source.unsplash.com/400x175/?github
description: API docs for the banners plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'banners']
---
import bannersObj from './banners.devdocs.json';
diff --git a/api_docs/bfetch.mdx b/api_docs/bfetch.mdx
index 1db99e15705fe..aab018f5b8aa9 100644
--- a/api_docs/bfetch.mdx
+++ b/api_docs/bfetch.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/bfetch
title: "bfetch"
image: https://source.unsplash.com/400x175/?github
description: API docs for the bfetch plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'bfetch']
---
import bfetchObj from './bfetch.devdocs.json';
diff --git a/api_docs/canvas.mdx b/api_docs/canvas.mdx
index 15bb752d66ce7..80aa8f92736ab 100644
--- a/api_docs/canvas.mdx
+++ b/api_docs/canvas.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/canvas
title: "canvas"
image: https://source.unsplash.com/400x175/?github
description: API docs for the canvas plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'canvas']
---
import canvasObj from './canvas.devdocs.json';
diff --git a/api_docs/cases.mdx b/api_docs/cases.mdx
index df344416c76dc..d0ffc1b5d621c 100644
--- a/api_docs/cases.mdx
+++ b/api_docs/cases.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/cases
title: "cases"
image: https://source.unsplash.com/400x175/?github
description: API docs for the cases plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cases']
---
import casesObj from './cases.devdocs.json';
diff --git a/api_docs/charts.mdx b/api_docs/charts.mdx
index 169153c085b83..07363f30a419f 100644
--- a/api_docs/charts.mdx
+++ b/api_docs/charts.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/charts
title: "charts"
image: https://source.unsplash.com/400x175/?github
description: API docs for the charts plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'charts']
---
import chartsObj from './charts.devdocs.json';
diff --git a/api_docs/cloud.devdocs.json b/api_docs/cloud.devdocs.json
index 08dbd1e77d8ef..354f3b99d8c05 100644
--- a/api_docs/cloud.devdocs.json
+++ b/api_docs/cloud.devdocs.json
@@ -893,11 +893,11 @@
"signature": [
"{ defaultSolution?: ",
{
- "pluginId": "cloud",
- "scope": "common",
- "docId": "kibCloudPluginApi",
- "section": "def-common.OnBoardingDefaultSolution",
- "text": "OnBoardingDefaultSolution"
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionId",
+ "text": "SolutionId"
},
" | undefined; }"
],
@@ -1212,11 +1212,11 @@
"signature": [
"{ defaultSolution?: ",
{
- "pluginId": "cloud",
- "scope": "common",
- "docId": "kibCloudPluginApi",
- "section": "def-common.OnBoardingDefaultSolution",
- "text": "OnBoardingDefaultSolution"
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionId",
+ "text": "SolutionId"
},
" | undefined; }"
],
@@ -1327,23 +1327,7 @@
"functions": [],
"interfaces": [],
"enums": [],
- "misc": [
- {
- "parentPluginId": "cloud",
- "id": "def-common.OnBoardingDefaultSolution",
- "type": "Type",
- "tags": [],
- "label": "OnBoardingDefaultSolution",
- "description": [],
- "signature": [
- "\"security\" | \"es\" | \"oblt\""
- ],
- "path": "x-pack/plugins/cloud/common/types.ts",
- "deprecated": false,
- "trackAdoption": false,
- "initialIsOpen": false
- }
- ],
+ "misc": [],
"objects": []
}
}
\ No newline at end of file
diff --git a/api_docs/cloud.mdx b/api_docs/cloud.mdx
index 251ef08480000..3fa2b6c3c3d56 100644
--- a/api_docs/cloud.mdx
+++ b/api_docs/cloud.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/cloud
title: "cloud"
image: https://source.unsplash.com/400x175/?github
description: API docs for the cloud plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cloud']
---
import cloudObj from './cloud.devdocs.json';
@@ -21,7 +21,7 @@ Contact [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core
| Public API count | Any count | Items lacking comments | Missing exports |
|-------------------|-----------|------------------------|-----------------|
-| 84 | 0 | 21 | 1 |
+| 83 | 0 | 20 | 1 |
## Client
@@ -39,8 +39,3 @@ Contact [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core
### Start
-## Common
-
-### Consts, variables and types
-
-
diff --git a/api_docs/cloud_data_migration.mdx b/api_docs/cloud_data_migration.mdx
index 170bd2249c4ec..12bdf56ea9f5e 100644
--- a/api_docs/cloud_data_migration.mdx
+++ b/api_docs/cloud_data_migration.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/cloudDataMigration
title: "cloudDataMigration"
image: https://source.unsplash.com/400x175/?github
description: API docs for the cloudDataMigration plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cloudDataMigration']
---
import cloudDataMigrationObj from './cloud_data_migration.devdocs.json';
diff --git a/api_docs/cloud_defend.mdx b/api_docs/cloud_defend.mdx
index 03be4730110c7..da9a113c4a0b8 100644
--- a/api_docs/cloud_defend.mdx
+++ b/api_docs/cloud_defend.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/cloudDefend
title: "cloudDefend"
image: https://source.unsplash.com/400x175/?github
description: API docs for the cloudDefend plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cloudDefend']
---
import cloudDefendObj from './cloud_defend.devdocs.json';
diff --git a/api_docs/cloud_security_posture.mdx b/api_docs/cloud_security_posture.mdx
index d1ac68f530e75..265c84d0a7617 100644
--- a/api_docs/cloud_security_posture.mdx
+++ b/api_docs/cloud_security_posture.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/cloudSecurityPosture
title: "cloudSecurityPosture"
image: https://source.unsplash.com/400x175/?github
description: API docs for the cloudSecurityPosture plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cloudSecurityPosture']
---
import cloudSecurityPostureObj from './cloud_security_posture.devdocs.json';
diff --git a/api_docs/console.mdx b/api_docs/console.mdx
index 856e50fc8170a..bb5583236e15e 100644
--- a/api_docs/console.mdx
+++ b/api_docs/console.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/console
title: "console"
image: https://source.unsplash.com/400x175/?github
description: API docs for the console plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'console']
---
import consoleObj from './console.devdocs.json';
diff --git a/api_docs/content_management.mdx b/api_docs/content_management.mdx
index 985a9a9eb8bc2..0a804e983babd 100644
--- a/api_docs/content_management.mdx
+++ b/api_docs/content_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/contentManagement
title: "contentManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the contentManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'contentManagement']
---
import contentManagementObj from './content_management.devdocs.json';
diff --git a/api_docs/controls.mdx b/api_docs/controls.mdx
index 1653e96ca136c..8cc7c190e1112 100644
--- a/api_docs/controls.mdx
+++ b/api_docs/controls.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/controls
title: "controls"
image: https://source.unsplash.com/400x175/?github
description: API docs for the controls plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'controls']
---
import controlsObj from './controls.devdocs.json';
diff --git a/api_docs/custom_integrations.mdx b/api_docs/custom_integrations.mdx
index 4dff33625e8b3..cb150e23e1050 100644
--- a/api_docs/custom_integrations.mdx
+++ b/api_docs/custom_integrations.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/customIntegrations
title: "customIntegrations"
image: https://source.unsplash.com/400x175/?github
description: API docs for the customIntegrations plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'customIntegrations']
---
import customIntegrationsObj from './custom_integrations.devdocs.json';
diff --git a/api_docs/dashboard.mdx b/api_docs/dashboard.mdx
index e7daa55dec604..a7f2c975f0651 100644
--- a/api_docs/dashboard.mdx
+++ b/api_docs/dashboard.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dashboard
title: "dashboard"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dashboard plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dashboard']
---
import dashboardObj from './dashboard.devdocs.json';
diff --git a/api_docs/dashboard_enhanced.mdx b/api_docs/dashboard_enhanced.mdx
index 83355ee361592..4f6000f7c6244 100644
--- a/api_docs/dashboard_enhanced.mdx
+++ b/api_docs/dashboard_enhanced.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dashboardEnhanced
title: "dashboardEnhanced"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dashboardEnhanced plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dashboardEnhanced']
---
import dashboardEnhancedObj from './dashboard_enhanced.devdocs.json';
diff --git a/api_docs/data.mdx b/api_docs/data.mdx
index c740fb0434d0a..67e9142d639b1 100644
--- a/api_docs/data.mdx
+++ b/api_docs/data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/data
title: "data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data']
---
import dataObj from './data.devdocs.json';
diff --git a/api_docs/data_quality.mdx b/api_docs/data_quality.mdx
index 9fd1edb9fb610..ee9c08e61fec5 100644
--- a/api_docs/data_quality.mdx
+++ b/api_docs/data_quality.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataQuality
title: "dataQuality"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataQuality plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataQuality']
---
import dataQualityObj from './data_quality.devdocs.json';
diff --git a/api_docs/data_query.mdx b/api_docs/data_query.mdx
index ef0844ba00fb9..30c1bc88b582f 100644
--- a/api_docs/data_query.mdx
+++ b/api_docs/data_query.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/data-query
title: "data.query"
image: https://source.unsplash.com/400x175/?github
description: API docs for the data.query plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data.query']
---
import dataQueryObj from './data_query.devdocs.json';
diff --git a/api_docs/data_search.mdx b/api_docs/data_search.mdx
index b8cf9b974f554..69a1e798e385b 100644
--- a/api_docs/data_search.mdx
+++ b/api_docs/data_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/data-search
title: "data.search"
image: https://source.unsplash.com/400x175/?github
description: API docs for the data.search plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data.search']
---
import dataSearchObj from './data_search.devdocs.json';
diff --git a/api_docs/data_usage.mdx b/api_docs/data_usage.mdx
index f61c0b4f69e9a..e0baf2f27cfc4 100644
--- a/api_docs/data_usage.mdx
+++ b/api_docs/data_usage.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataUsage
title: "dataUsage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataUsage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataUsage']
---
import dataUsageObj from './data_usage.devdocs.json';
diff --git a/api_docs/data_view_editor.mdx b/api_docs/data_view_editor.mdx
index 81e628eb05d18..076810b30bf83 100644
--- a/api_docs/data_view_editor.mdx
+++ b/api_docs/data_view_editor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataViewEditor
title: "dataViewEditor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataViewEditor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViewEditor']
---
import dataViewEditorObj from './data_view_editor.devdocs.json';
diff --git a/api_docs/data_view_field_editor.mdx b/api_docs/data_view_field_editor.mdx
index a39dbf004bb33..5231994ca6426 100644
--- a/api_docs/data_view_field_editor.mdx
+++ b/api_docs/data_view_field_editor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataViewFieldEditor
title: "dataViewFieldEditor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataViewFieldEditor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViewFieldEditor']
---
import dataViewFieldEditorObj from './data_view_field_editor.devdocs.json';
diff --git a/api_docs/data_view_management.mdx b/api_docs/data_view_management.mdx
index 823c0828c6fdc..73a866beac9f1 100644
--- a/api_docs/data_view_management.mdx
+++ b/api_docs/data_view_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataViewManagement
title: "dataViewManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataViewManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViewManagement']
---
import dataViewManagementObj from './data_view_management.devdocs.json';
diff --git a/api_docs/data_views.mdx b/api_docs/data_views.mdx
index de3721df7a5da..9a87e1ee9a4d4 100644
--- a/api_docs/data_views.mdx
+++ b/api_docs/data_views.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataViews
title: "dataViews"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataViews plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViews']
---
import dataViewsObj from './data_views.devdocs.json';
diff --git a/api_docs/data_visualizer.mdx b/api_docs/data_visualizer.mdx
index 75ff2402db68e..97230d1215956 100644
--- a/api_docs/data_visualizer.mdx
+++ b/api_docs/data_visualizer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/dataVisualizer
title: "dataVisualizer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the dataVisualizer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataVisualizer']
---
import dataVisualizerObj from './data_visualizer.devdocs.json';
diff --git a/api_docs/dataset_quality.mdx b/api_docs/dataset_quality.mdx
index 4749d14993bf2..3c0f9aae9b5b4 100644
--- a/api_docs/dataset_quality.mdx
+++ b/api_docs/dataset_quality.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/datasetQuality
title: "datasetQuality"
image: https://source.unsplash.com/400x175/?github
description: API docs for the datasetQuality plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'datasetQuality']
---
import datasetQualityObj from './dataset_quality.devdocs.json';
diff --git a/api_docs/deprecations_by_api.mdx b/api_docs/deprecations_by_api.mdx
index 43534a00ab7a8..b0fd973f96952 100644
--- a/api_docs/deprecations_by_api.mdx
+++ b/api_docs/deprecations_by_api.mdx
@@ -7,7 +7,7 @@ id: kibDevDocsDeprecationsByApi
slug: /kibana-dev-docs/api-meta/deprecated-api-list-by-api
title: Deprecated API usage by API
description: A list of deprecated APIs, which plugins are still referencing them, and when they need to be removed by.
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana']
---
diff --git a/api_docs/deprecations_by_plugin.mdx b/api_docs/deprecations_by_plugin.mdx
index cf16bd642557c..9a533304dcdae 100644
--- a/api_docs/deprecations_by_plugin.mdx
+++ b/api_docs/deprecations_by_plugin.mdx
@@ -7,7 +7,7 @@ id: kibDevDocsDeprecationsByPlugin
slug: /kibana-dev-docs/api-meta/deprecated-api-list-by-plugin
title: Deprecated API usage by plugin
description: A list of deprecated APIs, which plugins are still referencing them, and when they need to be removed by.
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana']
---
@@ -1239,7 +1239,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| Deprecated API | Reference location(s) | Remove By |
| ---------------|-----------|-----------|
-| | [create_lifecycle_executor.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts#:~:text=alertFactory), [create_persistence_rule_type_wrapper.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.ts#:~:text=alertFactory), [create_persistence_rule_type_wrapper.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.ts#:~:text=alertFactory), [rule_executor.test_helpers.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/rule_executor.test_helpers.ts#:~:text=alertFactory) | - |
+| | [create_persistence_rule_type_wrapper.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.ts#:~:text=alertFactory), [create_persistence_rule_type_wrapper.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.ts#:~:text=alertFactory), [rule_executor.test_helpers.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/utils/rule_executor.test_helpers.ts#:~:text=alertFactory) | - |
| | [alerts_client_factory.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/alert_data_client/alerts_client_factory.ts#:~:text=audit), [search_strategy.ts](https://github.com/elastic/kibana/tree/main/x-pack/plugins/rule_registry/server/search_strategy/search_strategy.ts#:~:text=audit) | - |
diff --git a/api_docs/deprecations_by_team.mdx b/api_docs/deprecations_by_team.mdx
index 58f8fdac128f3..bee5b436d4700 100644
--- a/api_docs/deprecations_by_team.mdx
+++ b/api_docs/deprecations_by_team.mdx
@@ -7,7 +7,7 @@ id: kibDevDocsDeprecationsDueByTeam
slug: /kibana-dev-docs/api-meta/deprecations-due-by-team
title: Deprecated APIs due to be removed, by team
description: Lists the teams that are referencing deprecated APIs with a remove by date.
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana']
---
diff --git a/api_docs/dev_tools.mdx b/api_docs/dev_tools.mdx
index 063a3229c60a4..43874a956324f 100644
--- a/api_docs/dev_tools.mdx
+++ b/api_docs/dev_tools.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/devTools
title: "devTools"
image: https://source.unsplash.com/400x175/?github
description: API docs for the devTools plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'devTools']
---
import devToolsObj from './dev_tools.devdocs.json';
diff --git a/api_docs/discover.mdx b/api_docs/discover.mdx
index cdb4b8ee68bb8..29646ab3ac57d 100644
--- a/api_docs/discover.mdx
+++ b/api_docs/discover.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/discover
title: "discover"
image: https://source.unsplash.com/400x175/?github
description: API docs for the discover plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'discover']
---
import discoverObj from './discover.devdocs.json';
diff --git a/api_docs/discover_enhanced.mdx b/api_docs/discover_enhanced.mdx
index ed52290858454..46b1d9f418733 100644
--- a/api_docs/discover_enhanced.mdx
+++ b/api_docs/discover_enhanced.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/discoverEnhanced
title: "discoverEnhanced"
image: https://source.unsplash.com/400x175/?github
description: API docs for the discoverEnhanced plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'discoverEnhanced']
---
import discoverEnhancedObj from './discover_enhanced.devdocs.json';
diff --git a/api_docs/discover_shared.mdx b/api_docs/discover_shared.mdx
index 1cf922207f7f3..eaf809fb79199 100644
--- a/api_docs/discover_shared.mdx
+++ b/api_docs/discover_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/discoverShared
title: "discoverShared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the discoverShared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'discoverShared']
---
import discoverSharedObj from './discover_shared.devdocs.json';
diff --git a/api_docs/ecs_data_quality_dashboard.mdx b/api_docs/ecs_data_quality_dashboard.mdx
index cb26ea768582c..39fc99a0c53e3 100644
--- a/api_docs/ecs_data_quality_dashboard.mdx
+++ b/api_docs/ecs_data_quality_dashboard.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/ecsDataQualityDashboard
title: "ecsDataQualityDashboard"
image: https://source.unsplash.com/400x175/?github
description: API docs for the ecsDataQualityDashboard plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ecsDataQualityDashboard']
---
import ecsDataQualityDashboardObj from './ecs_data_quality_dashboard.devdocs.json';
diff --git a/api_docs/elastic_assistant.mdx b/api_docs/elastic_assistant.mdx
index 46fbb14ab3516..b4dfe78e447e7 100644
--- a/api_docs/elastic_assistant.mdx
+++ b/api_docs/elastic_assistant.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/elasticAssistant
title: "elasticAssistant"
image: https://source.unsplash.com/400x175/?github
description: API docs for the elasticAssistant plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'elasticAssistant']
---
import elasticAssistantObj from './elastic_assistant.devdocs.json';
diff --git a/api_docs/embeddable.mdx b/api_docs/embeddable.mdx
index 7cf23f0cd2c0f..48ca1f3fb9e33 100644
--- a/api_docs/embeddable.mdx
+++ b/api_docs/embeddable.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/embeddable
title: "embeddable"
image: https://source.unsplash.com/400x175/?github
description: API docs for the embeddable plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'embeddable']
---
import embeddableObj from './embeddable.devdocs.json';
diff --git a/api_docs/embeddable_enhanced.mdx b/api_docs/embeddable_enhanced.mdx
index 4b6ddef7f8a77..8fcfeb30f1194 100644
--- a/api_docs/embeddable_enhanced.mdx
+++ b/api_docs/embeddable_enhanced.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/embeddableEnhanced
title: "embeddableEnhanced"
image: https://source.unsplash.com/400x175/?github
description: API docs for the embeddableEnhanced plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'embeddableEnhanced']
---
import embeddableEnhancedObj from './embeddable_enhanced.devdocs.json';
diff --git a/api_docs/encrypted_saved_objects.mdx b/api_docs/encrypted_saved_objects.mdx
index 1876644056bfb..3a966f5a29051 100644
--- a/api_docs/encrypted_saved_objects.mdx
+++ b/api_docs/encrypted_saved_objects.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/encryptedSavedObjects
title: "encryptedSavedObjects"
image: https://source.unsplash.com/400x175/?github
description: API docs for the encryptedSavedObjects plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'encryptedSavedObjects']
---
import encryptedSavedObjectsObj from './encrypted_saved_objects.devdocs.json';
diff --git a/api_docs/enterprise_search.mdx b/api_docs/enterprise_search.mdx
index 9720dc651ed3a..83586cb49c06d 100644
--- a/api_docs/enterprise_search.mdx
+++ b/api_docs/enterprise_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/enterpriseSearch
title: "enterpriseSearch"
image: https://source.unsplash.com/400x175/?github
description: API docs for the enterpriseSearch plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'enterpriseSearch']
---
import enterpriseSearchObj from './enterprise_search.devdocs.json';
diff --git a/api_docs/entities_data_access.mdx b/api_docs/entities_data_access.mdx
index 7e51ffbf68dea..d7d8523eebf99 100644
--- a/api_docs/entities_data_access.mdx
+++ b/api_docs/entities_data_access.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/entitiesDataAccess
title: "entitiesDataAccess"
image: https://source.unsplash.com/400x175/?github
description: API docs for the entitiesDataAccess plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'entitiesDataAccess']
---
import entitiesDataAccessObj from './entities_data_access.devdocs.json';
diff --git a/api_docs/entity_manager.mdx b/api_docs/entity_manager.mdx
index c23f21b04f6a9..b0602651a1dee 100644
--- a/api_docs/entity_manager.mdx
+++ b/api_docs/entity_manager.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/entityManager
title: "entityManager"
image: https://source.unsplash.com/400x175/?github
description: API docs for the entityManager plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'entityManager']
---
import entityManagerObj from './entity_manager.devdocs.json';
diff --git a/api_docs/es_ui_shared.mdx b/api_docs/es_ui_shared.mdx
index fc26296eabe44..1a4a85d6b496d 100644
--- a/api_docs/es_ui_shared.mdx
+++ b/api_docs/es_ui_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/esUiShared
title: "esUiShared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the esUiShared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'esUiShared']
---
import esUiSharedObj from './es_ui_shared.devdocs.json';
diff --git a/api_docs/esql.mdx b/api_docs/esql.mdx
index 74b174195a8d5..aca99ecafeff7 100644
--- a/api_docs/esql.mdx
+++ b/api_docs/esql.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/esql
title: "esql"
image: https://source.unsplash.com/400x175/?github
description: API docs for the esql plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'esql']
---
import esqlObj from './esql.devdocs.json';
diff --git a/api_docs/esql_data_grid.mdx b/api_docs/esql_data_grid.mdx
index b758d3ff20470..c99e59106b690 100644
--- a/api_docs/esql_data_grid.mdx
+++ b/api_docs/esql_data_grid.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/esqlDataGrid
title: "esqlDataGrid"
image: https://source.unsplash.com/400x175/?github
description: API docs for the esqlDataGrid plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'esqlDataGrid']
---
import esqlDataGridObj from './esql_data_grid.devdocs.json';
diff --git a/api_docs/event_annotation.mdx b/api_docs/event_annotation.mdx
index 9dd32a4770567..6af390ed57221 100644
--- a/api_docs/event_annotation.mdx
+++ b/api_docs/event_annotation.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/eventAnnotation
title: "eventAnnotation"
image: https://source.unsplash.com/400x175/?github
description: API docs for the eventAnnotation plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'eventAnnotation']
---
import eventAnnotationObj from './event_annotation.devdocs.json';
diff --git a/api_docs/event_annotation_listing.mdx b/api_docs/event_annotation_listing.mdx
index 56a79290ec18c..72d9cb9680699 100644
--- a/api_docs/event_annotation_listing.mdx
+++ b/api_docs/event_annotation_listing.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/eventAnnotationListing
title: "eventAnnotationListing"
image: https://source.unsplash.com/400x175/?github
description: API docs for the eventAnnotationListing plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'eventAnnotationListing']
---
import eventAnnotationListingObj from './event_annotation_listing.devdocs.json';
diff --git a/api_docs/event_log.mdx b/api_docs/event_log.mdx
index b7edd7f9fdcc9..a83e8dd9d931b 100644
--- a/api_docs/event_log.mdx
+++ b/api_docs/event_log.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/eventLog
title: "eventLog"
image: https://source.unsplash.com/400x175/?github
description: API docs for the eventLog plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'eventLog']
---
import eventLogObj from './event_log.devdocs.json';
diff --git a/api_docs/exploratory_view.mdx b/api_docs/exploratory_view.mdx
index 6715a40738de1..109d3f6d0a98f 100644
--- a/api_docs/exploratory_view.mdx
+++ b/api_docs/exploratory_view.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/exploratoryView
title: "exploratoryView"
image: https://source.unsplash.com/400x175/?github
description: API docs for the exploratoryView plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'exploratoryView']
---
import exploratoryViewObj from './exploratory_view.devdocs.json';
diff --git a/api_docs/expression_error.mdx b/api_docs/expression_error.mdx
index 9f2d96d4d33ba..133565f8e879d 100644
--- a/api_docs/expression_error.mdx
+++ b/api_docs/expression_error.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionError
title: "expressionError"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionError plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionError']
---
import expressionErrorObj from './expression_error.devdocs.json';
diff --git a/api_docs/expression_gauge.mdx b/api_docs/expression_gauge.mdx
index 6f896df011f3d..46458d8213c6f 100644
--- a/api_docs/expression_gauge.mdx
+++ b/api_docs/expression_gauge.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionGauge
title: "expressionGauge"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionGauge plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionGauge']
---
import expressionGaugeObj from './expression_gauge.devdocs.json';
diff --git a/api_docs/expression_heatmap.mdx b/api_docs/expression_heatmap.mdx
index ffc2225f1ebeb..ae37dea25da2f 100644
--- a/api_docs/expression_heatmap.mdx
+++ b/api_docs/expression_heatmap.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionHeatmap
title: "expressionHeatmap"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionHeatmap plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionHeatmap']
---
import expressionHeatmapObj from './expression_heatmap.devdocs.json';
diff --git a/api_docs/expression_image.mdx b/api_docs/expression_image.mdx
index 4a7c19bd94129..c1059b39d5fee 100644
--- a/api_docs/expression_image.mdx
+++ b/api_docs/expression_image.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionImage
title: "expressionImage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionImage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionImage']
---
import expressionImageObj from './expression_image.devdocs.json';
diff --git a/api_docs/expression_legacy_metric_vis.mdx b/api_docs/expression_legacy_metric_vis.mdx
index 8ce50e3444804..574acb6f47366 100644
--- a/api_docs/expression_legacy_metric_vis.mdx
+++ b/api_docs/expression_legacy_metric_vis.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionLegacyMetricVis
title: "expressionLegacyMetricVis"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionLegacyMetricVis plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionLegacyMetricVis']
---
import expressionLegacyMetricVisObj from './expression_legacy_metric_vis.devdocs.json';
diff --git a/api_docs/expression_metric.mdx b/api_docs/expression_metric.mdx
index 5afbab344b522..42ddb71d2360f 100644
--- a/api_docs/expression_metric.mdx
+++ b/api_docs/expression_metric.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionMetric
title: "expressionMetric"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionMetric plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionMetric']
---
import expressionMetricObj from './expression_metric.devdocs.json';
diff --git a/api_docs/expression_metric_vis.mdx b/api_docs/expression_metric_vis.mdx
index 85a016f86a66f..fc7ecb4582c1c 100644
--- a/api_docs/expression_metric_vis.mdx
+++ b/api_docs/expression_metric_vis.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionMetricVis
title: "expressionMetricVis"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionMetricVis plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionMetricVis']
---
import expressionMetricVisObj from './expression_metric_vis.devdocs.json';
diff --git a/api_docs/expression_partition_vis.mdx b/api_docs/expression_partition_vis.mdx
index 557b30c1aa942..f5ec3bb6de32b 100644
--- a/api_docs/expression_partition_vis.mdx
+++ b/api_docs/expression_partition_vis.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionPartitionVis
title: "expressionPartitionVis"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionPartitionVis plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionPartitionVis']
---
import expressionPartitionVisObj from './expression_partition_vis.devdocs.json';
diff --git a/api_docs/expression_repeat_image.mdx b/api_docs/expression_repeat_image.mdx
index 9a11b2e09fdb6..2d1b50c7a0af7 100644
--- a/api_docs/expression_repeat_image.mdx
+++ b/api_docs/expression_repeat_image.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionRepeatImage
title: "expressionRepeatImage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionRepeatImage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionRepeatImage']
---
import expressionRepeatImageObj from './expression_repeat_image.devdocs.json';
diff --git a/api_docs/expression_reveal_image.mdx b/api_docs/expression_reveal_image.mdx
index f2e6d18a83c56..4e44b72cb8e23 100644
--- a/api_docs/expression_reveal_image.mdx
+++ b/api_docs/expression_reveal_image.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionRevealImage
title: "expressionRevealImage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionRevealImage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionRevealImage']
---
import expressionRevealImageObj from './expression_reveal_image.devdocs.json';
diff --git a/api_docs/expression_shape.mdx b/api_docs/expression_shape.mdx
index 1377c47563571..35fc3a0b7fae7 100644
--- a/api_docs/expression_shape.mdx
+++ b/api_docs/expression_shape.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionShape
title: "expressionShape"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionShape plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionShape']
---
import expressionShapeObj from './expression_shape.devdocs.json';
diff --git a/api_docs/expression_tagcloud.mdx b/api_docs/expression_tagcloud.mdx
index 63099ef8b8e92..01dd6b05c4275 100644
--- a/api_docs/expression_tagcloud.mdx
+++ b/api_docs/expression_tagcloud.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionTagcloud
title: "expressionTagcloud"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionTagcloud plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionTagcloud']
---
import expressionTagcloudObj from './expression_tagcloud.devdocs.json';
diff --git a/api_docs/expression_x_y.mdx b/api_docs/expression_x_y.mdx
index 40e927a1c5e70..bef9018ce06f1 100644
--- a/api_docs/expression_x_y.mdx
+++ b/api_docs/expression_x_y.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressionXY
title: "expressionXY"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressionXY plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionXY']
---
import expressionXYObj from './expression_x_y.devdocs.json';
diff --git a/api_docs/expressions.mdx b/api_docs/expressions.mdx
index c3d251e854372..4bc9dd0984a5e 100644
--- a/api_docs/expressions.mdx
+++ b/api_docs/expressions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/expressions
title: "expressions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the expressions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressions']
---
import expressionsObj from './expressions.devdocs.json';
diff --git a/api_docs/features.mdx b/api_docs/features.mdx
index 769ba1e6cf651..5d199b694434e 100644
--- a/api_docs/features.mdx
+++ b/api_docs/features.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/features
title: "features"
image: https://source.unsplash.com/400x175/?github
description: API docs for the features plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'features']
---
import featuresObj from './features.devdocs.json';
diff --git a/api_docs/field_formats.mdx b/api_docs/field_formats.mdx
index 488a12e27a2a5..a55a7fcc5e9f0 100644
--- a/api_docs/field_formats.mdx
+++ b/api_docs/field_formats.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/fieldFormats
title: "fieldFormats"
image: https://source.unsplash.com/400x175/?github
description: API docs for the fieldFormats plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fieldFormats']
---
import fieldFormatsObj from './field_formats.devdocs.json';
diff --git a/api_docs/fields_metadata.mdx b/api_docs/fields_metadata.mdx
index 192dd3d06561c..935948319b021 100644
--- a/api_docs/fields_metadata.mdx
+++ b/api_docs/fields_metadata.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/fieldsMetadata
title: "fieldsMetadata"
image: https://source.unsplash.com/400x175/?github
description: API docs for the fieldsMetadata plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fieldsMetadata']
---
import fieldsMetadataObj from './fields_metadata.devdocs.json';
diff --git a/api_docs/file_upload.mdx b/api_docs/file_upload.mdx
index d0b20af87bd5e..c4738a05d8190 100644
--- a/api_docs/file_upload.mdx
+++ b/api_docs/file_upload.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/fileUpload
title: "fileUpload"
image: https://source.unsplash.com/400x175/?github
description: API docs for the fileUpload plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fileUpload']
---
import fileUploadObj from './file_upload.devdocs.json';
diff --git a/api_docs/files.mdx b/api_docs/files.mdx
index 1ad20f8380793..346afab7c85b6 100644
--- a/api_docs/files.mdx
+++ b/api_docs/files.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/files
title: "files"
image: https://source.unsplash.com/400x175/?github
description: API docs for the files plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'files']
---
import filesObj from './files.devdocs.json';
diff --git a/api_docs/files_management.mdx b/api_docs/files_management.mdx
index af0b7466105eb..9101e26b9daed 100644
--- a/api_docs/files_management.mdx
+++ b/api_docs/files_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/filesManagement
title: "filesManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the filesManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'filesManagement']
---
import filesManagementObj from './files_management.devdocs.json';
diff --git a/api_docs/fleet.mdx b/api_docs/fleet.mdx
index 71ef3d8990856..9a10cd91f5ce2 100644
--- a/api_docs/fleet.mdx
+++ b/api_docs/fleet.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/fleet
title: "fleet"
image: https://source.unsplash.com/400x175/?github
description: API docs for the fleet plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fleet']
---
import fleetObj from './fleet.devdocs.json';
diff --git a/api_docs/global_search.mdx b/api_docs/global_search.mdx
index 3dce64f18cb02..7282d4ec6322d 100644
--- a/api_docs/global_search.mdx
+++ b/api_docs/global_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/globalSearch
title: "globalSearch"
image: https://source.unsplash.com/400x175/?github
description: API docs for the globalSearch plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'globalSearch']
---
import globalSearchObj from './global_search.devdocs.json';
diff --git a/api_docs/guided_onboarding.mdx b/api_docs/guided_onboarding.mdx
index dfc49bd33d8c5..244c4600c5783 100644
--- a/api_docs/guided_onboarding.mdx
+++ b/api_docs/guided_onboarding.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/guidedOnboarding
title: "guidedOnboarding"
image: https://source.unsplash.com/400x175/?github
description: API docs for the guidedOnboarding plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'guidedOnboarding']
---
import guidedOnboardingObj from './guided_onboarding.devdocs.json';
diff --git a/api_docs/home.mdx b/api_docs/home.mdx
index ea78638f9c5ae..bf19a7bbaa3e1 100644
--- a/api_docs/home.mdx
+++ b/api_docs/home.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/home
title: "home"
image: https://source.unsplash.com/400x175/?github
description: API docs for the home plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'home']
---
import homeObj from './home.devdocs.json';
diff --git a/api_docs/image_embeddable.mdx b/api_docs/image_embeddable.mdx
index 9fbe5d7e6d1c9..203566a3f2915 100644
--- a/api_docs/image_embeddable.mdx
+++ b/api_docs/image_embeddable.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/imageEmbeddable
title: "imageEmbeddable"
image: https://source.unsplash.com/400x175/?github
description: API docs for the imageEmbeddable plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'imageEmbeddable']
---
import imageEmbeddableObj from './image_embeddable.devdocs.json';
diff --git a/api_docs/index_lifecycle_management.mdx b/api_docs/index_lifecycle_management.mdx
index d8e5f24cdb5a9..081f291a70dad 100644
--- a/api_docs/index_lifecycle_management.mdx
+++ b/api_docs/index_lifecycle_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/indexLifecycleManagement
title: "indexLifecycleManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the indexLifecycleManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'indexLifecycleManagement']
---
import indexLifecycleManagementObj from './index_lifecycle_management.devdocs.json';
diff --git a/api_docs/index_management.devdocs.json b/api_docs/index_management.devdocs.json
index ae73ce8dc81a9..d669189fc7e2a 100644
--- a/api_docs/index_management.devdocs.json
+++ b/api_docs/index_management.devdocs.json
@@ -2065,6 +2065,20 @@
"path": "x-pack/plugins/index_management/common/types/data_streams.ts",
"deprecated": false,
"trackAdoption": false
+ },
+ {
+ "parentPluginId": "indexManagement",
+ "id": "def-common.DataStream.indexMode",
+ "type": "CompoundType",
+ "tags": [],
+ "label": "indexMode",
+ "description": [],
+ "signature": [
+ "\"standard\" | \"time_series\" | \"logsdb\""
+ ],
+ "path": "x-pack/plugins/index_management/common/types/data_streams.ts",
+ "deprecated": false,
+ "trackAdoption": false
}
],
"initialIsOpen": false
@@ -2262,6 +2276,20 @@
"path": "x-pack/plugins/index_management/common/types/data_streams.ts",
"deprecated": false,
"trackAdoption": false
+ },
+ {
+ "parentPluginId": "indexManagement",
+ "id": "def-common.EnhancedDataStreamFromEs.index_mode",
+ "type": "CompoundType",
+ "tags": [],
+ "label": "index_mode",
+ "description": [],
+ "signature": [
+ "string | null | undefined"
+ ],
+ "path": "x-pack/plugins/index_management/common/types/data_streams.ts",
+ "deprecated": false,
+ "trackAdoption": false
}
],
"initialIsOpen": false
@@ -2615,145 +2643,6 @@
],
"initialIsOpen": false
},
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule",
- "type": "Interface",
- "tags": [],
- "label": "IndexModule",
- "description": [],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.number_of_shards",
- "type": "CompoundType",
- "tags": [],
- "label": "number_of_shards",
- "description": [],
- "signature": [
- "string | number"
- ],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.codec",
- "type": "string",
- "tags": [],
- "label": "codec",
- "description": [],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.routing_partition_size",
- "type": "number",
- "tags": [],
- "label": "routing_partition_size",
- "description": [],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.refresh_interval",
- "type": "string",
- "tags": [],
- "label": "refresh_interval",
- "description": [],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.load_fixed_bitset_filters_eagerly",
- "type": "boolean",
- "tags": [],
- "label": "load_fixed_bitset_filters_eagerly",
- "description": [],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.shard",
- "type": "Object",
- "tags": [],
- "label": "shard",
- "description": [],
- "signature": [
- "{ check_on_startup: boolean | \"checksum\"; }"
- ],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.number_of_replicas",
- "type": "number",
- "tags": [],
- "label": "number_of_replicas",
- "description": [],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.auto_expand_replicas",
- "type": "CompoundType",
- "tags": [],
- "label": "auto_expand_replicas",
- "description": [],
- "signature": [
- "string | false"
- ],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.lifecycle",
- "type": "Object",
- "tags": [],
- "label": "lifecycle",
- "description": [],
- "signature": [
- "LifecycleModule"
- ],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "indexManagement",
- "id": "def-common.IndexModule.routing",
- "type": "Object",
- "tags": [],
- "label": "routing",
- "description": [],
- "signature": [
- "{ allocation: { enable: \"none\" | \"all\" | \"primaries\" | \"new_primaries\"; }; rebalance: { enable: \"none\" | \"all\" | \"primaries\" | \"replicas\"; }; }"
- ],
- "path": "x-pack/plugins/index_management/common/types/indices.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ],
- "initialIsOpen": false
- },
{
"parentPluginId": "indexManagement",
"id": "def-common.IndexSettings",
@@ -2773,15 +2662,8 @@
"label": "index",
"description": [],
"signature": [
- "Partial<",
- {
- "pluginId": "indexManagement",
- "scope": "common",
- "docId": "kibIndexManagementPluginApi",
- "section": "def-common.IndexModule",
- "text": "IndexModule"
- },
- "> | undefined"
+ "IndicesIndexSettingsKeys",
+ " | undefined"
],
"path": "x-pack/plugins/index_management/common/types/indices.ts",
"deprecated": false,
diff --git a/api_docs/index_management.mdx b/api_docs/index_management.mdx
index 21c5d351e9427..e193809411717 100644
--- a/api_docs/index_management.mdx
+++ b/api_docs/index_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/indexManagement
title: "indexManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the indexManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'indexManagement']
---
import indexManagementObj from './index_management.devdocs.json';
@@ -21,7 +21,7 @@ Contact [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kiban
| Public API count | Any count | Items lacking comments | Missing exports |
|-------------------|-----------|------------------------|-----------------|
-| 250 | 0 | 245 | 1 |
+| 241 | 0 | 236 | 1 |
## Client
diff --git a/api_docs/inference.mdx b/api_docs/inference.mdx
index 5b466a235a471..a1c0bd1661a3d 100644
--- a/api_docs/inference.mdx
+++ b/api_docs/inference.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/inference
title: "inference"
image: https://source.unsplash.com/400x175/?github
description: API docs for the inference plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'inference']
---
import inferenceObj from './inference.devdocs.json';
diff --git a/api_docs/infra.mdx b/api_docs/infra.mdx
index aaab6bcc8312a..be7722b49842b 100644
--- a/api_docs/infra.mdx
+++ b/api_docs/infra.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/infra
title: "infra"
image: https://source.unsplash.com/400x175/?github
description: API docs for the infra plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'infra']
---
import infraObj from './infra.devdocs.json';
diff --git a/api_docs/ingest_pipelines.mdx b/api_docs/ingest_pipelines.mdx
index 0a25940b0d008..4f358a796db47 100644
--- a/api_docs/ingest_pipelines.mdx
+++ b/api_docs/ingest_pipelines.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/ingestPipelines
title: "ingestPipelines"
image: https://source.unsplash.com/400x175/?github
description: API docs for the ingestPipelines plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ingestPipelines']
---
import ingestPipelinesObj from './ingest_pipelines.devdocs.json';
diff --git a/api_docs/inspector.mdx b/api_docs/inspector.mdx
index 86c6065dd656f..b5beb5df3b4a8 100644
--- a/api_docs/inspector.mdx
+++ b/api_docs/inspector.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/inspector
title: "inspector"
image: https://source.unsplash.com/400x175/?github
description: API docs for the inspector plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'inspector']
---
import inspectorObj from './inspector.devdocs.json';
diff --git a/api_docs/integration_assistant.mdx b/api_docs/integration_assistant.mdx
index 4a336d1ed86a1..0f758fdd05b97 100644
--- a/api_docs/integration_assistant.mdx
+++ b/api_docs/integration_assistant.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/integrationAssistant
title: "integrationAssistant"
image: https://source.unsplash.com/400x175/?github
description: API docs for the integrationAssistant plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'integrationAssistant']
---
import integrationAssistantObj from './integration_assistant.devdocs.json';
diff --git a/api_docs/interactive_setup.mdx b/api_docs/interactive_setup.mdx
index aae7098217144..5dbddb2150676 100644
--- a/api_docs/interactive_setup.mdx
+++ b/api_docs/interactive_setup.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/interactiveSetup
title: "interactiveSetup"
image: https://source.unsplash.com/400x175/?github
description: API docs for the interactiveSetup plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'interactiveSetup']
---
import interactiveSetupObj from './interactive_setup.devdocs.json';
diff --git a/api_docs/inventory.mdx b/api_docs/inventory.mdx
index e6e707e6c6c59..0082a4be032e0 100644
--- a/api_docs/inventory.mdx
+++ b/api_docs/inventory.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/inventory
title: "inventory"
image: https://source.unsplash.com/400x175/?github
description: API docs for the inventory plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'inventory']
---
import inventoryObj from './inventory.devdocs.json';
diff --git a/api_docs/investigate.mdx b/api_docs/investigate.mdx
index 2cd302bbf6ea2..ac98731e7808d 100644
--- a/api_docs/investigate.mdx
+++ b/api_docs/investigate.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/investigate
title: "investigate"
image: https://source.unsplash.com/400x175/?github
description: API docs for the investigate plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'investigate']
---
import investigateObj from './investigate.devdocs.json';
diff --git a/api_docs/investigate_app.mdx b/api_docs/investigate_app.mdx
index 4d564028d2d04..f02e921b8e25d 100644
--- a/api_docs/investigate_app.mdx
+++ b/api_docs/investigate_app.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/investigateApp
title: "investigateApp"
image: https://source.unsplash.com/400x175/?github
description: API docs for the investigateApp plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'investigateApp']
---
import investigateAppObj from './investigate_app.devdocs.json';
diff --git a/api_docs/kbn_actions_types.mdx b/api_docs/kbn_actions_types.mdx
index 32a5df9e8a02d..9c77e9ab9e8a7 100644
--- a/api_docs/kbn_actions_types.mdx
+++ b/api_docs/kbn_actions_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-actions-types
title: "@kbn/actions-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/actions-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/actions-types']
---
import kbnActionsTypesObj from './kbn_actions_types.devdocs.json';
diff --git a/api_docs/kbn_ai_assistant.devdocs.json b/api_docs/kbn_ai_assistant.devdocs.json
index fd7ac303da36b..f80f569dd4300 100644
--- a/api_docs/kbn_ai_assistant.devdocs.json
+++ b/api_docs/kbn_ai_assistant.devdocs.json
@@ -349,7 +349,7 @@
"label": "ChatFlyout",
"description": [],
"signature": [
- "({\n initialTitle,\n initialMessages,\n initialFlyoutPositionMode,\n isOpen,\n onClose,\n navigateToConversation,\n}: { initialTitle: string; initialMessages: ",
+ "({\n initialTitle,\n initialMessages,\n initialFlyoutPositionMode,\n isOpen,\n onClose,\n navigateToConversation,\n hideConversationList,\n}: { initialTitle: string; initialMessages: ",
{
"pluginId": "observabilityAIAssistant",
"scope": "common",
@@ -365,7 +365,7 @@
"section": "def-public.FlyoutPositionMode",
"text": "FlyoutPositionMode"
},
- " | undefined; isOpen: boolean; onClose: () => void; navigateToConversation?: ((conversationId?: string | undefined) => void) | undefined; }) => React.JSX.Element | null"
+ " | undefined; isOpen: boolean; onClose: () => void; navigateToConversation?: ((conversationId?: string | undefined) => void) | undefined; hideConversationList?: boolean | undefined; }) => React.JSX.Element | null"
],
"path": "x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx",
"deprecated": false,
@@ -376,7 +376,7 @@
"id": "def-public.ChatFlyout.$1",
"type": "Object",
"tags": [],
- "label": "{\n initialTitle,\n initialMessages,\n initialFlyoutPositionMode,\n isOpen,\n onClose,\n navigateToConversation,\n}",
+ "label": "{\n initialTitle,\n initialMessages,\n initialFlyoutPositionMode,\n isOpen,\n onClose,\n navigateToConversation,\n hideConversationList,\n}",
"description": [],
"path": "x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx",
"deprecated": false,
@@ -493,6 +493,20 @@
}
],
"returnComment": []
+ },
+ {
+ "parentPluginId": "@kbn/ai-assistant",
+ "id": "def-public.ChatFlyout.$1.hideConversationList",
+ "type": "CompoundType",
+ "tags": [],
+ "label": "hideConversationList",
+ "description": [],
+ "signature": [
+ "boolean | undefined"
+ ],
+ "path": "x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx",
+ "deprecated": false,
+ "trackAdoption": false
}
]
}
diff --git a/api_docs/kbn_ai_assistant.mdx b/api_docs/kbn_ai_assistant.mdx
index c81901f628f21..9f4aebd335fff 100644
--- a/api_docs/kbn_ai_assistant.mdx
+++ b/api_docs/kbn_ai_assistant.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ai-assistant
title: "@kbn/ai-assistant"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ai-assistant plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ai-assistant']
---
import kbnAiAssistantObj from './kbn_ai_assistant.devdocs.json';
@@ -21,7 +21,7 @@ Contact [@elastic/search-kibana](https://github.com/orgs/elastic/teams/search-ki
| Public API count | Any count | Items lacking comments | Missing exports |
|-------------------|-----------|------------------------|-----------------|
-| 63 | 0 | 63 | 1 |
+| 64 | 0 | 64 | 1 |
## Client
diff --git a/api_docs/kbn_ai_assistant_common.mdx b/api_docs/kbn_ai_assistant_common.mdx
index 48d88f662e485..f55a0591246ee 100644
--- a/api_docs/kbn_ai_assistant_common.mdx
+++ b/api_docs/kbn_ai_assistant_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ai-assistant-common
title: "@kbn/ai-assistant-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ai-assistant-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ai-assistant-common']
---
import kbnAiAssistantCommonObj from './kbn_ai_assistant_common.devdocs.json';
diff --git a/api_docs/kbn_aiops_components.mdx b/api_docs/kbn_aiops_components.mdx
index 50e1707370ea3..dd5caccabf8bc 100644
--- a/api_docs/kbn_aiops_components.mdx
+++ b/api_docs/kbn_aiops_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-aiops-components
title: "@kbn/aiops-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/aiops-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/aiops-components']
---
import kbnAiopsComponentsObj from './kbn_aiops_components.devdocs.json';
diff --git a/api_docs/kbn_aiops_log_pattern_analysis.mdx b/api_docs/kbn_aiops_log_pattern_analysis.mdx
index 2586f478cd273..48a73e5acd0f6 100644
--- a/api_docs/kbn_aiops_log_pattern_analysis.mdx
+++ b/api_docs/kbn_aiops_log_pattern_analysis.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-aiops-log-pattern-analysis
title: "@kbn/aiops-log-pattern-analysis"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/aiops-log-pattern-analysis plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/aiops-log-pattern-analysis']
---
import kbnAiopsLogPatternAnalysisObj from './kbn_aiops_log_pattern_analysis.devdocs.json';
diff --git a/api_docs/kbn_aiops_log_rate_analysis.mdx b/api_docs/kbn_aiops_log_rate_analysis.mdx
index e840a29e25cbe..daa437a07bd5f 100644
--- a/api_docs/kbn_aiops_log_rate_analysis.mdx
+++ b/api_docs/kbn_aiops_log_rate_analysis.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-aiops-log-rate-analysis
title: "@kbn/aiops-log-rate-analysis"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/aiops-log-rate-analysis plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/aiops-log-rate-analysis']
---
import kbnAiopsLogRateAnalysisObj from './kbn_aiops_log_rate_analysis.devdocs.json';
diff --git a/api_docs/kbn_alerting_api_integration_helpers.mdx b/api_docs/kbn_alerting_api_integration_helpers.mdx
index c990cd10cc255..92c17eb6eacde 100644
--- a/api_docs/kbn_alerting_api_integration_helpers.mdx
+++ b/api_docs/kbn_alerting_api_integration_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerting-api-integration-helpers
title: "@kbn/alerting-api-integration-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerting-api-integration-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerting-api-integration-helpers']
---
import kbnAlertingApiIntegrationHelpersObj from './kbn_alerting_api_integration_helpers.devdocs.json';
diff --git a/api_docs/kbn_alerting_comparators.mdx b/api_docs/kbn_alerting_comparators.mdx
index 9ee92d18d08aa..15ed3315d7b40 100644
--- a/api_docs/kbn_alerting_comparators.mdx
+++ b/api_docs/kbn_alerting_comparators.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerting-comparators
title: "@kbn/alerting-comparators"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerting-comparators plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerting-comparators']
---
import kbnAlertingComparatorsObj from './kbn_alerting_comparators.devdocs.json';
diff --git a/api_docs/kbn_alerting_state_types.mdx b/api_docs/kbn_alerting_state_types.mdx
index f1905aabde50f..a9f2ce380e071 100644
--- a/api_docs/kbn_alerting_state_types.mdx
+++ b/api_docs/kbn_alerting_state_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerting-state-types
title: "@kbn/alerting-state-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerting-state-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerting-state-types']
---
import kbnAlertingStateTypesObj from './kbn_alerting_state_types.devdocs.json';
diff --git a/api_docs/kbn_alerting_types.mdx b/api_docs/kbn_alerting_types.mdx
index 975bcc0bedf2c..3d19ac7b48650 100644
--- a/api_docs/kbn_alerting_types.mdx
+++ b/api_docs/kbn_alerting_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerting-types
title: "@kbn/alerting-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerting-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerting-types']
---
import kbnAlertingTypesObj from './kbn_alerting_types.devdocs.json';
diff --git a/api_docs/kbn_alerts_as_data_utils.mdx b/api_docs/kbn_alerts_as_data_utils.mdx
index b78adecd2d77d..21e95086eb253 100644
--- a/api_docs/kbn_alerts_as_data_utils.mdx
+++ b/api_docs/kbn_alerts_as_data_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerts-as-data-utils
title: "@kbn/alerts-as-data-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerts-as-data-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerts-as-data-utils']
---
import kbnAlertsAsDataUtilsObj from './kbn_alerts_as_data_utils.devdocs.json';
diff --git a/api_docs/kbn_alerts_grouping.mdx b/api_docs/kbn_alerts_grouping.mdx
index 18f139b97fd27..f23736a4d367a 100644
--- a/api_docs/kbn_alerts_grouping.mdx
+++ b/api_docs/kbn_alerts_grouping.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerts-grouping
title: "@kbn/alerts-grouping"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerts-grouping plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerts-grouping']
---
import kbnAlertsGroupingObj from './kbn_alerts_grouping.devdocs.json';
diff --git a/api_docs/kbn_alerts_ui_shared.mdx b/api_docs/kbn_alerts_ui_shared.mdx
index 66c37fae09f75..62bb549d68383 100644
--- a/api_docs/kbn_alerts_ui_shared.mdx
+++ b/api_docs/kbn_alerts_ui_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-alerts-ui-shared
title: "@kbn/alerts-ui-shared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/alerts-ui-shared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerts-ui-shared']
---
import kbnAlertsUiSharedObj from './kbn_alerts_ui_shared.devdocs.json';
diff --git a/api_docs/kbn_analytics.mdx b/api_docs/kbn_analytics.mdx
index 187c873d6109b..4be82fdf20524 100644
--- a/api_docs/kbn_analytics.mdx
+++ b/api_docs/kbn_analytics.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-analytics
title: "@kbn/analytics"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/analytics plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/analytics']
---
import kbnAnalyticsObj from './kbn_analytics.devdocs.json';
diff --git a/api_docs/kbn_analytics_collection_utils.mdx b/api_docs/kbn_analytics_collection_utils.mdx
index d7696f72d2dd9..39ee997b1385e 100644
--- a/api_docs/kbn_analytics_collection_utils.mdx
+++ b/api_docs/kbn_analytics_collection_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-analytics-collection-utils
title: "@kbn/analytics-collection-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/analytics-collection-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/analytics-collection-utils']
---
import kbnAnalyticsCollectionUtilsObj from './kbn_analytics_collection_utils.devdocs.json';
diff --git a/api_docs/kbn_apm_config_loader.mdx b/api_docs/kbn_apm_config_loader.mdx
index bfac2496edd05..8302ada28edd3 100644
--- a/api_docs/kbn_apm_config_loader.mdx
+++ b/api_docs/kbn_apm_config_loader.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-apm-config-loader
title: "@kbn/apm-config-loader"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/apm-config-loader plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-config-loader']
---
import kbnApmConfigLoaderObj from './kbn_apm_config_loader.devdocs.json';
diff --git a/api_docs/kbn_apm_data_view.mdx b/api_docs/kbn_apm_data_view.mdx
index 1dad958a0cede..effc6193a456d 100644
--- a/api_docs/kbn_apm_data_view.mdx
+++ b/api_docs/kbn_apm_data_view.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-apm-data-view
title: "@kbn/apm-data-view"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/apm-data-view plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-data-view']
---
import kbnApmDataViewObj from './kbn_apm_data_view.devdocs.json';
diff --git a/api_docs/kbn_apm_synthtrace.mdx b/api_docs/kbn_apm_synthtrace.mdx
index e6ca119d5fd9f..67faa87a55c38 100644
--- a/api_docs/kbn_apm_synthtrace.mdx
+++ b/api_docs/kbn_apm_synthtrace.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-apm-synthtrace
title: "@kbn/apm-synthtrace"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/apm-synthtrace plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-synthtrace']
---
import kbnApmSynthtraceObj from './kbn_apm_synthtrace.devdocs.json';
diff --git a/api_docs/kbn_apm_synthtrace_client.mdx b/api_docs/kbn_apm_synthtrace_client.mdx
index c13f34a72c3d3..01c1ce40b1766 100644
--- a/api_docs/kbn_apm_synthtrace_client.mdx
+++ b/api_docs/kbn_apm_synthtrace_client.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-apm-synthtrace-client
title: "@kbn/apm-synthtrace-client"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/apm-synthtrace-client plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-synthtrace-client']
---
import kbnApmSynthtraceClientObj from './kbn_apm_synthtrace_client.devdocs.json';
diff --git a/api_docs/kbn_apm_types.mdx b/api_docs/kbn_apm_types.mdx
index 11fec4934efbd..adb6cb79aedd6 100644
--- a/api_docs/kbn_apm_types.mdx
+++ b/api_docs/kbn_apm_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-apm-types
title: "@kbn/apm-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/apm-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-types']
---
import kbnApmTypesObj from './kbn_apm_types.devdocs.json';
diff --git a/api_docs/kbn_apm_utils.mdx b/api_docs/kbn_apm_utils.mdx
index 5f36122557e1f..ab776fead78c5 100644
--- a/api_docs/kbn_apm_utils.mdx
+++ b/api_docs/kbn_apm_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-apm-utils
title: "@kbn/apm-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/apm-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-utils']
---
import kbnApmUtilsObj from './kbn_apm_utils.devdocs.json';
diff --git a/api_docs/kbn_avc_banner.mdx b/api_docs/kbn_avc_banner.mdx
index c66298a4d05d9..174350a3f50a9 100644
--- a/api_docs/kbn_avc_banner.mdx
+++ b/api_docs/kbn_avc_banner.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-avc-banner
title: "@kbn/avc-banner"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/avc-banner plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/avc-banner']
---
import kbnAvcBannerObj from './kbn_avc_banner.devdocs.json';
diff --git a/api_docs/kbn_axe_config.mdx b/api_docs/kbn_axe_config.mdx
index 3424bace48c01..2fa43e0e12409 100644
--- a/api_docs/kbn_axe_config.mdx
+++ b/api_docs/kbn_axe_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-axe-config
title: "@kbn/axe-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/axe-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/axe-config']
---
import kbnAxeConfigObj from './kbn_axe_config.devdocs.json';
diff --git a/api_docs/kbn_bfetch_error.mdx b/api_docs/kbn_bfetch_error.mdx
index 9b0271952264d..f6c29c8fa8dd9 100644
--- a/api_docs/kbn_bfetch_error.mdx
+++ b/api_docs/kbn_bfetch_error.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-bfetch-error
title: "@kbn/bfetch-error"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/bfetch-error plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/bfetch-error']
---
import kbnBfetchErrorObj from './kbn_bfetch_error.devdocs.json';
diff --git a/api_docs/kbn_calculate_auto.mdx b/api_docs/kbn_calculate_auto.mdx
index 509b489728e59..47d9f891e6dd1 100644
--- a/api_docs/kbn_calculate_auto.mdx
+++ b/api_docs/kbn_calculate_auto.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-calculate-auto
title: "@kbn/calculate-auto"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/calculate-auto plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/calculate-auto']
---
import kbnCalculateAutoObj from './kbn_calculate_auto.devdocs.json';
diff --git a/api_docs/kbn_calculate_width_from_char_count.mdx b/api_docs/kbn_calculate_width_from_char_count.mdx
index 0f768e70a6c1f..bd3e7bb4179c9 100644
--- a/api_docs/kbn_calculate_width_from_char_count.mdx
+++ b/api_docs/kbn_calculate_width_from_char_count.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-calculate-width-from-char-count
title: "@kbn/calculate-width-from-char-count"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/calculate-width-from-char-count plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/calculate-width-from-char-count']
---
import kbnCalculateWidthFromCharCountObj from './kbn_calculate_width_from_char_count.devdocs.json';
diff --git a/api_docs/kbn_cases_components.mdx b/api_docs/kbn_cases_components.mdx
index c997c60d69601..e56c686c9de02 100644
--- a/api_docs/kbn_cases_components.mdx
+++ b/api_docs/kbn_cases_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cases-components
title: "@kbn/cases-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cases-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cases-components']
---
import kbnCasesComponentsObj from './kbn_cases_components.devdocs.json';
diff --git a/api_docs/kbn_cbor.mdx b/api_docs/kbn_cbor.mdx
index a250847ab2892..34f5f0f8f868b 100644
--- a/api_docs/kbn_cbor.mdx
+++ b/api_docs/kbn_cbor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cbor
title: "@kbn/cbor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cbor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cbor']
---
import kbnCborObj from './kbn_cbor.devdocs.json';
diff --git a/api_docs/kbn_cell_actions.mdx b/api_docs/kbn_cell_actions.mdx
index 723029e4e6af9..06f6ec322a4e2 100644
--- a/api_docs/kbn_cell_actions.mdx
+++ b/api_docs/kbn_cell_actions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cell-actions
title: "@kbn/cell-actions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cell-actions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cell-actions']
---
import kbnCellActionsObj from './kbn_cell_actions.devdocs.json';
diff --git a/api_docs/kbn_chart_expressions_common.mdx b/api_docs/kbn_chart_expressions_common.mdx
index 359217fbd5313..4dc5fa8a15ce3 100644
--- a/api_docs/kbn_chart_expressions_common.mdx
+++ b/api_docs/kbn_chart_expressions_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-chart-expressions-common
title: "@kbn/chart-expressions-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/chart-expressions-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/chart-expressions-common']
---
import kbnChartExpressionsCommonObj from './kbn_chart_expressions_common.devdocs.json';
diff --git a/api_docs/kbn_chart_icons.mdx b/api_docs/kbn_chart_icons.mdx
index 3cbafc7e6da35..cc871bd3657b1 100644
--- a/api_docs/kbn_chart_icons.mdx
+++ b/api_docs/kbn_chart_icons.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-chart-icons
title: "@kbn/chart-icons"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/chart-icons plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/chart-icons']
---
import kbnChartIconsObj from './kbn_chart_icons.devdocs.json';
diff --git a/api_docs/kbn_ci_stats_core.mdx b/api_docs/kbn_ci_stats_core.mdx
index 23c3726d55cad..3ee9e2a79bcbc 100644
--- a/api_docs/kbn_ci_stats_core.mdx
+++ b/api_docs/kbn_ci_stats_core.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ci-stats-core
title: "@kbn/ci-stats-core"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ci-stats-core plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ci-stats-core']
---
import kbnCiStatsCoreObj from './kbn_ci_stats_core.devdocs.json';
diff --git a/api_docs/kbn_ci_stats_performance_metrics.mdx b/api_docs/kbn_ci_stats_performance_metrics.mdx
index 4b1cae5bab942..92fecc6431205 100644
--- a/api_docs/kbn_ci_stats_performance_metrics.mdx
+++ b/api_docs/kbn_ci_stats_performance_metrics.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ci-stats-performance-metrics
title: "@kbn/ci-stats-performance-metrics"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ci-stats-performance-metrics plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ci-stats-performance-metrics']
---
import kbnCiStatsPerformanceMetricsObj from './kbn_ci_stats_performance_metrics.devdocs.json';
diff --git a/api_docs/kbn_ci_stats_reporter.mdx b/api_docs/kbn_ci_stats_reporter.mdx
index dee9b03fad18c..ec170f08a0a12 100644
--- a/api_docs/kbn_ci_stats_reporter.mdx
+++ b/api_docs/kbn_ci_stats_reporter.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ci-stats-reporter
title: "@kbn/ci-stats-reporter"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ci-stats-reporter plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ci-stats-reporter']
---
import kbnCiStatsReporterObj from './kbn_ci_stats_reporter.devdocs.json';
diff --git a/api_docs/kbn_cli_dev_mode.mdx b/api_docs/kbn_cli_dev_mode.mdx
index 22752f21924fb..fa68238f7d869 100644
--- a/api_docs/kbn_cli_dev_mode.mdx
+++ b/api_docs/kbn_cli_dev_mode.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cli-dev-mode
title: "@kbn/cli-dev-mode"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cli-dev-mode plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cli-dev-mode']
---
import kbnCliDevModeObj from './kbn_cli_dev_mode.devdocs.json';
diff --git a/api_docs/kbn_cloud_security_posture.mdx b/api_docs/kbn_cloud_security_posture.mdx
index a2f98fc4e6bdb..c69aa9f74804e 100644
--- a/api_docs/kbn_cloud_security_posture.mdx
+++ b/api_docs/kbn_cloud_security_posture.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cloud-security-posture
title: "@kbn/cloud-security-posture"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cloud-security-posture plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cloud-security-posture']
---
import kbnCloudSecurityPostureObj from './kbn_cloud_security_posture.devdocs.json';
diff --git a/api_docs/kbn_cloud_security_posture_common.mdx b/api_docs/kbn_cloud_security_posture_common.mdx
index f90d4571c314a..2ed3347b58bb7 100644
--- a/api_docs/kbn_cloud_security_posture_common.mdx
+++ b/api_docs/kbn_cloud_security_posture_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cloud-security-posture-common
title: "@kbn/cloud-security-posture-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cloud-security-posture-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cloud-security-posture-common']
---
import kbnCloudSecurityPostureCommonObj from './kbn_cloud_security_posture_common.devdocs.json';
diff --git a/api_docs/kbn_cloud_security_posture_graph.mdx b/api_docs/kbn_cloud_security_posture_graph.mdx
index 7af53cc1918b8..d0b9c70ba5b76 100644
--- a/api_docs/kbn_cloud_security_posture_graph.mdx
+++ b/api_docs/kbn_cloud_security_posture_graph.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cloud-security-posture-graph
title: "@kbn/cloud-security-posture-graph"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cloud-security-posture-graph plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cloud-security-posture-graph']
---
import kbnCloudSecurityPostureGraphObj from './kbn_cloud_security_posture_graph.devdocs.json';
diff --git a/api_docs/kbn_code_editor.mdx b/api_docs/kbn_code_editor.mdx
index 1627d03000b9d..6213792bbe697 100644
--- a/api_docs/kbn_code_editor.mdx
+++ b/api_docs/kbn_code_editor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-code-editor
title: "@kbn/code-editor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/code-editor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/code-editor']
---
import kbnCodeEditorObj from './kbn_code_editor.devdocs.json';
diff --git a/api_docs/kbn_code_editor_mock.mdx b/api_docs/kbn_code_editor_mock.mdx
index 7095e36f96ea1..7ba6695edffe4 100644
--- a/api_docs/kbn_code_editor_mock.mdx
+++ b/api_docs/kbn_code_editor_mock.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-code-editor-mock
title: "@kbn/code-editor-mock"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/code-editor-mock plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/code-editor-mock']
---
import kbnCodeEditorMockObj from './kbn_code_editor_mock.devdocs.json';
diff --git a/api_docs/kbn_code_owners.mdx b/api_docs/kbn_code_owners.mdx
index dbb9570ef8f2b..f736234760aa6 100644
--- a/api_docs/kbn_code_owners.mdx
+++ b/api_docs/kbn_code_owners.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-code-owners
title: "@kbn/code-owners"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/code-owners plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/code-owners']
---
import kbnCodeOwnersObj from './kbn_code_owners.devdocs.json';
diff --git a/api_docs/kbn_coloring.mdx b/api_docs/kbn_coloring.mdx
index 2955233c44185..c78bba1b4b0f6 100644
--- a/api_docs/kbn_coloring.mdx
+++ b/api_docs/kbn_coloring.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-coloring
title: "@kbn/coloring"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/coloring plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/coloring']
---
import kbnColoringObj from './kbn_coloring.devdocs.json';
diff --git a/api_docs/kbn_config.mdx b/api_docs/kbn_config.mdx
index 6bc171cd0b4d8..ca819f5cd11e0 100644
--- a/api_docs/kbn_config.mdx
+++ b/api_docs/kbn_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-config
title: "@kbn/config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/config']
---
import kbnConfigObj from './kbn_config.devdocs.json';
diff --git a/api_docs/kbn_config_mocks.mdx b/api_docs/kbn_config_mocks.mdx
index a31b5499e1b16..6920ebca02423 100644
--- a/api_docs/kbn_config_mocks.mdx
+++ b/api_docs/kbn_config_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-config-mocks
title: "@kbn/config-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/config-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/config-mocks']
---
import kbnConfigMocksObj from './kbn_config_mocks.devdocs.json';
diff --git a/api_docs/kbn_config_schema.mdx b/api_docs/kbn_config_schema.mdx
index 6b17a90c82bfb..314e395ef9a60 100644
--- a/api_docs/kbn_config_schema.mdx
+++ b/api_docs/kbn_config_schema.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-config-schema
title: "@kbn/config-schema"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/config-schema plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/config-schema']
---
import kbnConfigSchemaObj from './kbn_config_schema.devdocs.json';
diff --git a/api_docs/kbn_content_management_content_editor.mdx b/api_docs/kbn_content_management_content_editor.mdx
index 4989fe8d4776a..5093af3ad6894 100644
--- a/api_docs/kbn_content_management_content_editor.mdx
+++ b/api_docs/kbn_content_management_content_editor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-content-editor
title: "@kbn/content-management-content-editor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-content-editor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-content-editor']
---
import kbnContentManagementContentEditorObj from './kbn_content_management_content_editor.devdocs.json';
diff --git a/api_docs/kbn_content_management_content_insights_public.mdx b/api_docs/kbn_content_management_content_insights_public.mdx
index 3dd25a1da2934..ff9cf1d6cb6f1 100644
--- a/api_docs/kbn_content_management_content_insights_public.mdx
+++ b/api_docs/kbn_content_management_content_insights_public.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-content-insights-public
title: "@kbn/content-management-content-insights-public"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-content-insights-public plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-content-insights-public']
---
import kbnContentManagementContentInsightsPublicObj from './kbn_content_management_content_insights_public.devdocs.json';
diff --git a/api_docs/kbn_content_management_content_insights_server.mdx b/api_docs/kbn_content_management_content_insights_server.mdx
index e56d5a53fd8b8..c2fb3b38c69df 100644
--- a/api_docs/kbn_content_management_content_insights_server.mdx
+++ b/api_docs/kbn_content_management_content_insights_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-content-insights-server
title: "@kbn/content-management-content-insights-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-content-insights-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-content-insights-server']
---
import kbnContentManagementContentInsightsServerObj from './kbn_content_management_content_insights_server.devdocs.json';
diff --git a/api_docs/kbn_content_management_favorites_public.mdx b/api_docs/kbn_content_management_favorites_public.mdx
index 2c9df39c2ded9..f839ff271bea5 100644
--- a/api_docs/kbn_content_management_favorites_public.mdx
+++ b/api_docs/kbn_content_management_favorites_public.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-favorites-public
title: "@kbn/content-management-favorites-public"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-favorites-public plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-favorites-public']
---
import kbnContentManagementFavoritesPublicObj from './kbn_content_management_favorites_public.devdocs.json';
diff --git a/api_docs/kbn_content_management_favorites_server.mdx b/api_docs/kbn_content_management_favorites_server.mdx
index 25daab9552cd0..5db1bbe6c7c06 100644
--- a/api_docs/kbn_content_management_favorites_server.mdx
+++ b/api_docs/kbn_content_management_favorites_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-favorites-server
title: "@kbn/content-management-favorites-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-favorites-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-favorites-server']
---
import kbnContentManagementFavoritesServerObj from './kbn_content_management_favorites_server.devdocs.json';
diff --git a/api_docs/kbn_content_management_tabbed_table_list_view.mdx b/api_docs/kbn_content_management_tabbed_table_list_view.mdx
index ae74d373678ba..b386d3267d885 100644
--- a/api_docs/kbn_content_management_tabbed_table_list_view.mdx
+++ b/api_docs/kbn_content_management_tabbed_table_list_view.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-tabbed-table-list-view
title: "@kbn/content-management-tabbed-table-list-view"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-tabbed-table-list-view plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-tabbed-table-list-view']
---
import kbnContentManagementTabbedTableListViewObj from './kbn_content_management_tabbed_table_list_view.devdocs.json';
diff --git a/api_docs/kbn_content_management_table_list_view.mdx b/api_docs/kbn_content_management_table_list_view.mdx
index cef126c9d6687..9574aea73af9d 100644
--- a/api_docs/kbn_content_management_table_list_view.mdx
+++ b/api_docs/kbn_content_management_table_list_view.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-table-list-view
title: "@kbn/content-management-table-list-view"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-table-list-view plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-table-list-view']
---
import kbnContentManagementTableListViewObj from './kbn_content_management_table_list_view.devdocs.json';
diff --git a/api_docs/kbn_content_management_table_list_view_common.mdx b/api_docs/kbn_content_management_table_list_view_common.mdx
index 30bc6d9b0742b..8ffb60bc661b1 100644
--- a/api_docs/kbn_content_management_table_list_view_common.mdx
+++ b/api_docs/kbn_content_management_table_list_view_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-table-list-view-common
title: "@kbn/content-management-table-list-view-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-table-list-view-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-table-list-view-common']
---
import kbnContentManagementTableListViewCommonObj from './kbn_content_management_table_list_view_common.devdocs.json';
diff --git a/api_docs/kbn_content_management_table_list_view_table.mdx b/api_docs/kbn_content_management_table_list_view_table.mdx
index fad99e751315b..86bede673f7f7 100644
--- a/api_docs/kbn_content_management_table_list_view_table.mdx
+++ b/api_docs/kbn_content_management_table_list_view_table.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-table-list-view-table
title: "@kbn/content-management-table-list-view-table"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-table-list-view-table plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-table-list-view-table']
---
import kbnContentManagementTableListViewTableObj from './kbn_content_management_table_list_view_table.devdocs.json';
diff --git a/api_docs/kbn_content_management_user_profiles.mdx b/api_docs/kbn_content_management_user_profiles.mdx
index 675c05a2bdf43..08d0ca41a0ddf 100644
--- a/api_docs/kbn_content_management_user_profiles.mdx
+++ b/api_docs/kbn_content_management_user_profiles.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-user-profiles
title: "@kbn/content-management-user-profiles"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-user-profiles plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-user-profiles']
---
import kbnContentManagementUserProfilesObj from './kbn_content_management_user_profiles.devdocs.json';
diff --git a/api_docs/kbn_content_management_utils.mdx b/api_docs/kbn_content_management_utils.mdx
index e51decce255dd..fead3a0c4219a 100644
--- a/api_docs/kbn_content_management_utils.mdx
+++ b/api_docs/kbn_content_management_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-content-management-utils
title: "@kbn/content-management-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/content-management-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/content-management-utils']
---
import kbnContentManagementUtilsObj from './kbn_content_management_utils.devdocs.json';
diff --git a/api_docs/kbn_core_analytics_browser.mdx b/api_docs/kbn_core_analytics_browser.mdx
index 7c7e873af2603..6ea9a15b5a1ee 100644
--- a/api_docs/kbn_core_analytics_browser.mdx
+++ b/api_docs/kbn_core_analytics_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-analytics-browser
title: "@kbn/core-analytics-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-analytics-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-analytics-browser']
---
import kbnCoreAnalyticsBrowserObj from './kbn_core_analytics_browser.devdocs.json';
diff --git a/api_docs/kbn_core_analytics_browser_internal.mdx b/api_docs/kbn_core_analytics_browser_internal.mdx
index ff147b34df299..5da9894ceaaf4 100644
--- a/api_docs/kbn_core_analytics_browser_internal.mdx
+++ b/api_docs/kbn_core_analytics_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-analytics-browser-internal
title: "@kbn/core-analytics-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-analytics-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-analytics-browser-internal']
---
import kbnCoreAnalyticsBrowserInternalObj from './kbn_core_analytics_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_analytics_browser_mocks.mdx b/api_docs/kbn_core_analytics_browser_mocks.mdx
index 0288abef4fb88..a6d457a2b1f0a 100644
--- a/api_docs/kbn_core_analytics_browser_mocks.mdx
+++ b/api_docs/kbn_core_analytics_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-analytics-browser-mocks
title: "@kbn/core-analytics-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-analytics-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-analytics-browser-mocks']
---
import kbnCoreAnalyticsBrowserMocksObj from './kbn_core_analytics_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_analytics_server.mdx b/api_docs/kbn_core_analytics_server.mdx
index 92435ee6285cd..0de038e5c0cc8 100644
--- a/api_docs/kbn_core_analytics_server.mdx
+++ b/api_docs/kbn_core_analytics_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-analytics-server
title: "@kbn/core-analytics-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-analytics-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-analytics-server']
---
import kbnCoreAnalyticsServerObj from './kbn_core_analytics_server.devdocs.json';
diff --git a/api_docs/kbn_core_analytics_server_internal.mdx b/api_docs/kbn_core_analytics_server_internal.mdx
index 2366c65412d1c..fe2f352269943 100644
--- a/api_docs/kbn_core_analytics_server_internal.mdx
+++ b/api_docs/kbn_core_analytics_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-analytics-server-internal
title: "@kbn/core-analytics-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-analytics-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-analytics-server-internal']
---
import kbnCoreAnalyticsServerInternalObj from './kbn_core_analytics_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_analytics_server_mocks.mdx b/api_docs/kbn_core_analytics_server_mocks.mdx
index 0e96743290499..1bb4be4940a06 100644
--- a/api_docs/kbn_core_analytics_server_mocks.mdx
+++ b/api_docs/kbn_core_analytics_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-analytics-server-mocks
title: "@kbn/core-analytics-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-analytics-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-analytics-server-mocks']
---
import kbnCoreAnalyticsServerMocksObj from './kbn_core_analytics_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_application_browser.mdx b/api_docs/kbn_core_application_browser.mdx
index 7204859046277..22276eb1bc561 100644
--- a/api_docs/kbn_core_application_browser.mdx
+++ b/api_docs/kbn_core_application_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-application-browser
title: "@kbn/core-application-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-application-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-application-browser']
---
import kbnCoreApplicationBrowserObj from './kbn_core_application_browser.devdocs.json';
diff --git a/api_docs/kbn_core_application_browser_internal.mdx b/api_docs/kbn_core_application_browser_internal.mdx
index 9097d3b65ec16..060e08e11932a 100644
--- a/api_docs/kbn_core_application_browser_internal.mdx
+++ b/api_docs/kbn_core_application_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-application-browser-internal
title: "@kbn/core-application-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-application-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-application-browser-internal']
---
import kbnCoreApplicationBrowserInternalObj from './kbn_core_application_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_application_browser_mocks.mdx b/api_docs/kbn_core_application_browser_mocks.mdx
index cdba4613492e9..8e8e6e35f2ba6 100644
--- a/api_docs/kbn_core_application_browser_mocks.mdx
+++ b/api_docs/kbn_core_application_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-application-browser-mocks
title: "@kbn/core-application-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-application-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-application-browser-mocks']
---
import kbnCoreApplicationBrowserMocksObj from './kbn_core_application_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_application_common.mdx b/api_docs/kbn_core_application_common.mdx
index eab78e65e4275..c633544970950 100644
--- a/api_docs/kbn_core_application_common.mdx
+++ b/api_docs/kbn_core_application_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-application-common
title: "@kbn/core-application-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-application-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-application-common']
---
import kbnCoreApplicationCommonObj from './kbn_core_application_common.devdocs.json';
diff --git a/api_docs/kbn_core_apps_browser_internal.mdx b/api_docs/kbn_core_apps_browser_internal.mdx
index c47be71c76338..272b0f57ca72d 100644
--- a/api_docs/kbn_core_apps_browser_internal.mdx
+++ b/api_docs/kbn_core_apps_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-apps-browser-internal
title: "@kbn/core-apps-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-apps-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-apps-browser-internal']
---
import kbnCoreAppsBrowserInternalObj from './kbn_core_apps_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_apps_browser_mocks.mdx b/api_docs/kbn_core_apps_browser_mocks.mdx
index ac728f4eace2e..309456742cc12 100644
--- a/api_docs/kbn_core_apps_browser_mocks.mdx
+++ b/api_docs/kbn_core_apps_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-apps-browser-mocks
title: "@kbn/core-apps-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-apps-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-apps-browser-mocks']
---
import kbnCoreAppsBrowserMocksObj from './kbn_core_apps_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_apps_server_internal.mdx b/api_docs/kbn_core_apps_server_internal.mdx
index df6e9e4cb7ede..36e7ffcc1fd45 100644
--- a/api_docs/kbn_core_apps_server_internal.mdx
+++ b/api_docs/kbn_core_apps_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-apps-server-internal
title: "@kbn/core-apps-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-apps-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-apps-server-internal']
---
import kbnCoreAppsServerInternalObj from './kbn_core_apps_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_base_browser_mocks.mdx b/api_docs/kbn_core_base_browser_mocks.mdx
index f2c731647bf80..72ec2fbd89e87 100644
--- a/api_docs/kbn_core_base_browser_mocks.mdx
+++ b/api_docs/kbn_core_base_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-base-browser-mocks
title: "@kbn/core-base-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-base-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-base-browser-mocks']
---
import kbnCoreBaseBrowserMocksObj from './kbn_core_base_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_base_common.mdx b/api_docs/kbn_core_base_common.mdx
index e0b01b51f936f..d36cd1ea19d8c 100644
--- a/api_docs/kbn_core_base_common.mdx
+++ b/api_docs/kbn_core_base_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-base-common
title: "@kbn/core-base-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-base-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-base-common']
---
import kbnCoreBaseCommonObj from './kbn_core_base_common.devdocs.json';
diff --git a/api_docs/kbn_core_base_server_internal.mdx b/api_docs/kbn_core_base_server_internal.mdx
index 2a6a565511f7d..3feb90f04c411 100644
--- a/api_docs/kbn_core_base_server_internal.mdx
+++ b/api_docs/kbn_core_base_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-base-server-internal
title: "@kbn/core-base-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-base-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-base-server-internal']
---
import kbnCoreBaseServerInternalObj from './kbn_core_base_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_base_server_mocks.mdx b/api_docs/kbn_core_base_server_mocks.mdx
index e52fa71f4430b..a11caeccc157b 100644
--- a/api_docs/kbn_core_base_server_mocks.mdx
+++ b/api_docs/kbn_core_base_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-base-server-mocks
title: "@kbn/core-base-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-base-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-base-server-mocks']
---
import kbnCoreBaseServerMocksObj from './kbn_core_base_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_capabilities_browser_mocks.mdx b/api_docs/kbn_core_capabilities_browser_mocks.mdx
index 0f16d13d060a5..376c9d2063a8f 100644
--- a/api_docs/kbn_core_capabilities_browser_mocks.mdx
+++ b/api_docs/kbn_core_capabilities_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-capabilities-browser-mocks
title: "@kbn/core-capabilities-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-capabilities-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-capabilities-browser-mocks']
---
import kbnCoreCapabilitiesBrowserMocksObj from './kbn_core_capabilities_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_capabilities_common.mdx b/api_docs/kbn_core_capabilities_common.mdx
index 42038044ebda1..4e77a01235170 100644
--- a/api_docs/kbn_core_capabilities_common.mdx
+++ b/api_docs/kbn_core_capabilities_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-capabilities-common
title: "@kbn/core-capabilities-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-capabilities-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-capabilities-common']
---
import kbnCoreCapabilitiesCommonObj from './kbn_core_capabilities_common.devdocs.json';
diff --git a/api_docs/kbn_core_capabilities_server.mdx b/api_docs/kbn_core_capabilities_server.mdx
index 7fe4ab533d8f2..0b9e04fdd97b2 100644
--- a/api_docs/kbn_core_capabilities_server.mdx
+++ b/api_docs/kbn_core_capabilities_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-capabilities-server
title: "@kbn/core-capabilities-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-capabilities-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-capabilities-server']
---
import kbnCoreCapabilitiesServerObj from './kbn_core_capabilities_server.devdocs.json';
diff --git a/api_docs/kbn_core_capabilities_server_mocks.mdx b/api_docs/kbn_core_capabilities_server_mocks.mdx
index ae68e9ed6ba17..33bfeec38de7a 100644
--- a/api_docs/kbn_core_capabilities_server_mocks.mdx
+++ b/api_docs/kbn_core_capabilities_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-capabilities-server-mocks
title: "@kbn/core-capabilities-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-capabilities-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-capabilities-server-mocks']
---
import kbnCoreCapabilitiesServerMocksObj from './kbn_core_capabilities_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_chrome_browser.devdocs.json b/api_docs/kbn_core_chrome_browser.devdocs.json
index e7c0392a3f999..74cc5c0a5be1b 100644
--- a/api_docs/kbn_core_chrome_browser.devdocs.json
+++ b/api_docs/kbn_core_chrome_browser.devdocs.json
@@ -3259,6 +3259,20 @@
"deprecated": false,
"trackAdoption": false,
"children": [
+ {
+ "parentPluginId": "@kbn/core-chrome-browser",
+ "id": "def-public.NavigationTreeDefinitionUI.id",
+ "type": "CompoundType",
+ "tags": [],
+ "label": "id",
+ "description": [],
+ "signature": [
+ "\"security\" | \"es\" | \"oblt\""
+ ],
+ "path": "packages/core/chrome/core-chrome-browser/src/project_navigation.ts",
+ "deprecated": false,
+ "trackAdoption": false
+ },
{
"parentPluginId": "@kbn/core-chrome-browser",
"id": "def-public.NavigationTreeDefinitionUI.body",
@@ -3630,12 +3644,15 @@
{
"parentPluginId": "@kbn/core-chrome-browser",
"id": "def-public.SolutionNavigationDefinition.id",
- "type": "string",
+ "type": "CompoundType",
"tags": [],
"label": "id",
"description": [
"Unique id for the solution navigation."
],
+ "signature": [
+ "\"security\" | \"es\" | \"oblt\""
+ ],
"path": "packages/core/chrome/core-chrome-browser/src/project_navigation.ts",
"deprecated": false,
"trackAdoption": false
@@ -3736,50 +3753,6 @@
}
],
"initialIsOpen": false
- },
- {
- "parentPluginId": "@kbn/core-chrome-browser",
- "id": "def-public.SolutionNavigationDefinitions",
- "type": "Interface",
- "tags": [],
- "label": "SolutionNavigationDefinitions",
- "description": [],
- "path": "packages/core/chrome/core-chrome-browser/src/project_navigation.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "@kbn/core-chrome-browser",
- "id": "def-public.SolutionNavigationDefinitions.Unnamed",
- "type": "IndexSignature",
- "tags": [],
- "label": "[id: string]: SolutionNavigationDefinition",
- "description": [],
- "signature": [
- "[id: string]: ",
- {
- "pluginId": "@kbn/core-chrome-browser",
- "scope": "public",
- "docId": "kibKbnCoreChromeBrowserPluginApi",
- "section": "def-public.SolutionNavigationDefinition",
- "text": "SolutionNavigationDefinition"
- },
- "<",
- {
- "pluginId": "@kbn/core-chrome-browser",
- "scope": "public",
- "docId": "kibKbnCoreChromeBrowserPluginApi",
- "section": "def-public.AppDeepLinkId",
- "text": "AppDeepLinkId"
- },
- ">"
- ],
- "path": "packages/core/chrome/core-chrome-browser/src/project_navigation.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ],
- "initialIsOpen": false
}
],
"enums": [],
@@ -4226,6 +4199,84 @@
"deprecated": false,
"trackAdoption": false,
"initialIsOpen": false
+ },
+ {
+ "parentPluginId": "@kbn/core-chrome-browser",
+ "id": "def-public.SolutionId",
+ "type": "Type",
+ "tags": [],
+ "label": "SolutionId",
+ "description": [],
+ "signature": [
+ "\"security\" | \"es\" | \"oblt\""
+ ],
+ "path": "packages/core/chrome/core-chrome-browser/src/project_navigation.ts",
+ "deprecated": false,
+ "trackAdoption": false,
+ "initialIsOpen": false
+ },
+ {
+ "parentPluginId": "@kbn/core-chrome-browser",
+ "id": "def-public.SolutionNavigationDefinitions",
+ "type": "Type",
+ "tags": [],
+ "label": "SolutionNavigationDefinitions",
+ "description": [],
+ "signature": [
+ "{ security?: ",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionNavigationDefinition",
+ "text": "SolutionNavigationDefinition"
+ },
+ "<",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.AppDeepLinkId",
+ "text": "AppDeepLinkId"
+ },
+ "> | undefined; es?: ",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionNavigationDefinition",
+ "text": "SolutionNavigationDefinition"
+ },
+ "<",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.AppDeepLinkId",
+ "text": "AppDeepLinkId"
+ },
+ "> | undefined; oblt?: ",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionNavigationDefinition",
+ "text": "SolutionNavigationDefinition"
+ },
+ "<",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.AppDeepLinkId",
+ "text": "AppDeepLinkId"
+ },
+ "> | undefined; }"
+ ],
+ "path": "packages/core/chrome/core-chrome-browser/src/project_navigation.ts",
+ "deprecated": false,
+ "trackAdoption": false,
+ "initialIsOpen": false
}
],
"objects": []
diff --git a/api_docs/kbn_core_chrome_browser.mdx b/api_docs/kbn_core_chrome_browser.mdx
index 28f5fd530093b..e5fcf858f4958 100644
--- a/api_docs/kbn_core_chrome_browser.mdx
+++ b/api_docs/kbn_core_chrome_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-chrome-browser
title: "@kbn/core-chrome-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-chrome-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-chrome-browser']
---
import kbnCoreChromeBrowserObj from './kbn_core_chrome_browser.devdocs.json';
@@ -21,7 +21,7 @@ Contact [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sh
| Public API count | Any count | Items lacking comments | Missing exports |
|-------------------|-----------|------------------------|-----------------|
-| 210 | 0 | 103 | 0 |
+| 211 | 0 | 104 | 0 |
## Client
diff --git a/api_docs/kbn_core_chrome_browser_mocks.mdx b/api_docs/kbn_core_chrome_browser_mocks.mdx
index 6157cb5f65ecf..9e6570053f74b 100644
--- a/api_docs/kbn_core_chrome_browser_mocks.mdx
+++ b/api_docs/kbn_core_chrome_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-chrome-browser-mocks
title: "@kbn/core-chrome-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-chrome-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-chrome-browser-mocks']
---
import kbnCoreChromeBrowserMocksObj from './kbn_core_chrome_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_config_server_internal.mdx b/api_docs/kbn_core_config_server_internal.mdx
index 8577b8a3b17a7..36b8723c641ff 100644
--- a/api_docs/kbn_core_config_server_internal.mdx
+++ b/api_docs/kbn_core_config_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-config-server-internal
title: "@kbn/core-config-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-config-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-config-server-internal']
---
import kbnCoreConfigServerInternalObj from './kbn_core_config_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_browser.mdx b/api_docs/kbn_core_custom_branding_browser.mdx
index 044b5adc6c481..b4000b5997f13 100644
--- a/api_docs/kbn_core_custom_branding_browser.mdx
+++ b/api_docs/kbn_core_custom_branding_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-browser
title: "@kbn/core-custom-branding-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-browser']
---
import kbnCoreCustomBrandingBrowserObj from './kbn_core_custom_branding_browser.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_browser_internal.mdx b/api_docs/kbn_core_custom_branding_browser_internal.mdx
index 61985be165f20..7450bcf7129c3 100644
--- a/api_docs/kbn_core_custom_branding_browser_internal.mdx
+++ b/api_docs/kbn_core_custom_branding_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-browser-internal
title: "@kbn/core-custom-branding-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-browser-internal']
---
import kbnCoreCustomBrandingBrowserInternalObj from './kbn_core_custom_branding_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_browser_mocks.mdx b/api_docs/kbn_core_custom_branding_browser_mocks.mdx
index e1f85d75515a5..d48ce8fe7dc08 100644
--- a/api_docs/kbn_core_custom_branding_browser_mocks.mdx
+++ b/api_docs/kbn_core_custom_branding_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-browser-mocks
title: "@kbn/core-custom-branding-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-browser-mocks']
---
import kbnCoreCustomBrandingBrowserMocksObj from './kbn_core_custom_branding_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_common.mdx b/api_docs/kbn_core_custom_branding_common.mdx
index ad4e7ed2c4892..08a5b24fab14c 100644
--- a/api_docs/kbn_core_custom_branding_common.mdx
+++ b/api_docs/kbn_core_custom_branding_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-common
title: "@kbn/core-custom-branding-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-common']
---
import kbnCoreCustomBrandingCommonObj from './kbn_core_custom_branding_common.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_server.mdx b/api_docs/kbn_core_custom_branding_server.mdx
index 566ff55fe96c3..aa860de0b7473 100644
--- a/api_docs/kbn_core_custom_branding_server.mdx
+++ b/api_docs/kbn_core_custom_branding_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-server
title: "@kbn/core-custom-branding-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-server']
---
import kbnCoreCustomBrandingServerObj from './kbn_core_custom_branding_server.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_server_internal.mdx b/api_docs/kbn_core_custom_branding_server_internal.mdx
index dc7c2d40b9c39..f6e33df5421c1 100644
--- a/api_docs/kbn_core_custom_branding_server_internal.mdx
+++ b/api_docs/kbn_core_custom_branding_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-server-internal
title: "@kbn/core-custom-branding-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-server-internal']
---
import kbnCoreCustomBrandingServerInternalObj from './kbn_core_custom_branding_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_custom_branding_server_mocks.mdx b/api_docs/kbn_core_custom_branding_server_mocks.mdx
index cedfe6f6a3128..0ad756867a747 100644
--- a/api_docs/kbn_core_custom_branding_server_mocks.mdx
+++ b/api_docs/kbn_core_custom_branding_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-custom-branding-server-mocks
title: "@kbn/core-custom-branding-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-custom-branding-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-custom-branding-server-mocks']
---
import kbnCoreCustomBrandingServerMocksObj from './kbn_core_custom_branding_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_browser.mdx b/api_docs/kbn_core_deprecations_browser.mdx
index 583aa79e644a0..f680d3d812f55 100644
--- a/api_docs/kbn_core_deprecations_browser.mdx
+++ b/api_docs/kbn_core_deprecations_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-browser
title: "@kbn/core-deprecations-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-browser']
---
import kbnCoreDeprecationsBrowserObj from './kbn_core_deprecations_browser.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_browser_internal.mdx b/api_docs/kbn_core_deprecations_browser_internal.mdx
index 9126bca1269a2..8e4be1e6de60f 100644
--- a/api_docs/kbn_core_deprecations_browser_internal.mdx
+++ b/api_docs/kbn_core_deprecations_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-browser-internal
title: "@kbn/core-deprecations-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-browser-internal']
---
import kbnCoreDeprecationsBrowserInternalObj from './kbn_core_deprecations_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_browser_mocks.mdx b/api_docs/kbn_core_deprecations_browser_mocks.mdx
index 58323ea64166d..b5f21b60a8f69 100644
--- a/api_docs/kbn_core_deprecations_browser_mocks.mdx
+++ b/api_docs/kbn_core_deprecations_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-browser-mocks
title: "@kbn/core-deprecations-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-browser-mocks']
---
import kbnCoreDeprecationsBrowserMocksObj from './kbn_core_deprecations_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_common.mdx b/api_docs/kbn_core_deprecations_common.mdx
index 74a6f0ead274a..2cb12eac8efad 100644
--- a/api_docs/kbn_core_deprecations_common.mdx
+++ b/api_docs/kbn_core_deprecations_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-common
title: "@kbn/core-deprecations-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-common']
---
import kbnCoreDeprecationsCommonObj from './kbn_core_deprecations_common.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_server.mdx b/api_docs/kbn_core_deprecations_server.mdx
index ccb3f15ed59e5..072a6742bfd7e 100644
--- a/api_docs/kbn_core_deprecations_server.mdx
+++ b/api_docs/kbn_core_deprecations_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-server
title: "@kbn/core-deprecations-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-server']
---
import kbnCoreDeprecationsServerObj from './kbn_core_deprecations_server.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_server_internal.mdx b/api_docs/kbn_core_deprecations_server_internal.mdx
index f175a6e47fa27..d27bf5dd3375d 100644
--- a/api_docs/kbn_core_deprecations_server_internal.mdx
+++ b/api_docs/kbn_core_deprecations_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-server-internal
title: "@kbn/core-deprecations-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-server-internal']
---
import kbnCoreDeprecationsServerInternalObj from './kbn_core_deprecations_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_deprecations_server_mocks.mdx b/api_docs/kbn_core_deprecations_server_mocks.mdx
index 20c6d63a9111e..dd730b724cf71 100644
--- a/api_docs/kbn_core_deprecations_server_mocks.mdx
+++ b/api_docs/kbn_core_deprecations_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-deprecations-server-mocks
title: "@kbn/core-deprecations-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-deprecations-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-deprecations-server-mocks']
---
import kbnCoreDeprecationsServerMocksObj from './kbn_core_deprecations_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_doc_links_browser.mdx b/api_docs/kbn_core_doc_links_browser.mdx
index b8d0e344da708..dd8b108d9b70f 100644
--- a/api_docs/kbn_core_doc_links_browser.mdx
+++ b/api_docs/kbn_core_doc_links_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-doc-links-browser
title: "@kbn/core-doc-links-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-doc-links-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-doc-links-browser']
---
import kbnCoreDocLinksBrowserObj from './kbn_core_doc_links_browser.devdocs.json';
diff --git a/api_docs/kbn_core_doc_links_browser_mocks.mdx b/api_docs/kbn_core_doc_links_browser_mocks.mdx
index 398c9de4f1af8..4fa2a34b07f81 100644
--- a/api_docs/kbn_core_doc_links_browser_mocks.mdx
+++ b/api_docs/kbn_core_doc_links_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-doc-links-browser-mocks
title: "@kbn/core-doc-links-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-doc-links-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-doc-links-browser-mocks']
---
import kbnCoreDocLinksBrowserMocksObj from './kbn_core_doc_links_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_doc_links_server.mdx b/api_docs/kbn_core_doc_links_server.mdx
index 3f07be1ba90b7..02dbf2f80f3df 100644
--- a/api_docs/kbn_core_doc_links_server.mdx
+++ b/api_docs/kbn_core_doc_links_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-doc-links-server
title: "@kbn/core-doc-links-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-doc-links-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-doc-links-server']
---
import kbnCoreDocLinksServerObj from './kbn_core_doc_links_server.devdocs.json';
diff --git a/api_docs/kbn_core_doc_links_server_mocks.mdx b/api_docs/kbn_core_doc_links_server_mocks.mdx
index bd8aa0dfde06a..806f4c37c27a8 100644
--- a/api_docs/kbn_core_doc_links_server_mocks.mdx
+++ b/api_docs/kbn_core_doc_links_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-doc-links-server-mocks
title: "@kbn/core-doc-links-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-doc-links-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-doc-links-server-mocks']
---
import kbnCoreDocLinksServerMocksObj from './kbn_core_doc_links_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_elasticsearch_client_server_internal.mdx b/api_docs/kbn_core_elasticsearch_client_server_internal.mdx
index 86ef87be6606c..0c967f7f33e4f 100644
--- a/api_docs/kbn_core_elasticsearch_client_server_internal.mdx
+++ b/api_docs/kbn_core_elasticsearch_client_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-elasticsearch-client-server-internal
title: "@kbn/core-elasticsearch-client-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-elasticsearch-client-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-elasticsearch-client-server-internal']
---
import kbnCoreElasticsearchClientServerInternalObj from './kbn_core_elasticsearch_client_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_elasticsearch_client_server_mocks.mdx b/api_docs/kbn_core_elasticsearch_client_server_mocks.mdx
index 8b63b7dc697e6..ad224bb3244ac 100644
--- a/api_docs/kbn_core_elasticsearch_client_server_mocks.mdx
+++ b/api_docs/kbn_core_elasticsearch_client_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-elasticsearch-client-server-mocks
title: "@kbn/core-elasticsearch-client-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-elasticsearch-client-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-elasticsearch-client-server-mocks']
---
import kbnCoreElasticsearchClientServerMocksObj from './kbn_core_elasticsearch_client_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_elasticsearch_server.mdx b/api_docs/kbn_core_elasticsearch_server.mdx
index b3e13453883d9..f7d3f5abe448a 100644
--- a/api_docs/kbn_core_elasticsearch_server.mdx
+++ b/api_docs/kbn_core_elasticsearch_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-elasticsearch-server
title: "@kbn/core-elasticsearch-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-elasticsearch-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-elasticsearch-server']
---
import kbnCoreElasticsearchServerObj from './kbn_core_elasticsearch_server.devdocs.json';
diff --git a/api_docs/kbn_core_elasticsearch_server_internal.mdx b/api_docs/kbn_core_elasticsearch_server_internal.mdx
index 6369b6e71142a..9bc05a5fcffdb 100644
--- a/api_docs/kbn_core_elasticsearch_server_internal.mdx
+++ b/api_docs/kbn_core_elasticsearch_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-elasticsearch-server-internal
title: "@kbn/core-elasticsearch-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-elasticsearch-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-elasticsearch-server-internal']
---
import kbnCoreElasticsearchServerInternalObj from './kbn_core_elasticsearch_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_elasticsearch_server_mocks.mdx b/api_docs/kbn_core_elasticsearch_server_mocks.mdx
index 14f044bb5e938..82fe06225c2a4 100644
--- a/api_docs/kbn_core_elasticsearch_server_mocks.mdx
+++ b/api_docs/kbn_core_elasticsearch_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-elasticsearch-server-mocks
title: "@kbn/core-elasticsearch-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-elasticsearch-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-elasticsearch-server-mocks']
---
import kbnCoreElasticsearchServerMocksObj from './kbn_core_elasticsearch_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_environment_server_internal.mdx b/api_docs/kbn_core_environment_server_internal.mdx
index d9d00a4e793b2..e2b6219d0bf79 100644
--- a/api_docs/kbn_core_environment_server_internal.mdx
+++ b/api_docs/kbn_core_environment_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-environment-server-internal
title: "@kbn/core-environment-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-environment-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-environment-server-internal']
---
import kbnCoreEnvironmentServerInternalObj from './kbn_core_environment_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_environment_server_mocks.mdx b/api_docs/kbn_core_environment_server_mocks.mdx
index f9381acf2f90b..9d7bba4866ada 100644
--- a/api_docs/kbn_core_environment_server_mocks.mdx
+++ b/api_docs/kbn_core_environment_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-environment-server-mocks
title: "@kbn/core-environment-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-environment-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-environment-server-mocks']
---
import kbnCoreEnvironmentServerMocksObj from './kbn_core_environment_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_browser.mdx b/api_docs/kbn_core_execution_context_browser.mdx
index f26a408a099fe..03e1200905154 100644
--- a/api_docs/kbn_core_execution_context_browser.mdx
+++ b/api_docs/kbn_core_execution_context_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-browser
title: "@kbn/core-execution-context-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-browser']
---
import kbnCoreExecutionContextBrowserObj from './kbn_core_execution_context_browser.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_browser_internal.mdx b/api_docs/kbn_core_execution_context_browser_internal.mdx
index c5b98914082a4..eea7b9c6a40ee 100644
--- a/api_docs/kbn_core_execution_context_browser_internal.mdx
+++ b/api_docs/kbn_core_execution_context_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-browser-internal
title: "@kbn/core-execution-context-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-browser-internal']
---
import kbnCoreExecutionContextBrowserInternalObj from './kbn_core_execution_context_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_browser_mocks.mdx b/api_docs/kbn_core_execution_context_browser_mocks.mdx
index 0f1855dcdc853..afde840e9fb1d 100644
--- a/api_docs/kbn_core_execution_context_browser_mocks.mdx
+++ b/api_docs/kbn_core_execution_context_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-browser-mocks
title: "@kbn/core-execution-context-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-browser-mocks']
---
import kbnCoreExecutionContextBrowserMocksObj from './kbn_core_execution_context_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_common.mdx b/api_docs/kbn_core_execution_context_common.mdx
index f6890799fdb83..c5d6c2604915f 100644
--- a/api_docs/kbn_core_execution_context_common.mdx
+++ b/api_docs/kbn_core_execution_context_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-common
title: "@kbn/core-execution-context-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-common']
---
import kbnCoreExecutionContextCommonObj from './kbn_core_execution_context_common.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_server.mdx b/api_docs/kbn_core_execution_context_server.mdx
index ade11d337ad60..493a78f48f5ea 100644
--- a/api_docs/kbn_core_execution_context_server.mdx
+++ b/api_docs/kbn_core_execution_context_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-server
title: "@kbn/core-execution-context-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-server']
---
import kbnCoreExecutionContextServerObj from './kbn_core_execution_context_server.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_server_internal.mdx b/api_docs/kbn_core_execution_context_server_internal.mdx
index 8907927e4d2d3..1b52ccbfe62a9 100644
--- a/api_docs/kbn_core_execution_context_server_internal.mdx
+++ b/api_docs/kbn_core_execution_context_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-server-internal
title: "@kbn/core-execution-context-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-server-internal']
---
import kbnCoreExecutionContextServerInternalObj from './kbn_core_execution_context_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_execution_context_server_mocks.mdx b/api_docs/kbn_core_execution_context_server_mocks.mdx
index 27ac321cd7ae7..a9fa2eee4318b 100644
--- a/api_docs/kbn_core_execution_context_server_mocks.mdx
+++ b/api_docs/kbn_core_execution_context_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-execution-context-server-mocks
title: "@kbn/core-execution-context-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-execution-context-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-execution-context-server-mocks']
---
import kbnCoreExecutionContextServerMocksObj from './kbn_core_execution_context_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_fatal_errors_browser.mdx b/api_docs/kbn_core_fatal_errors_browser.mdx
index a4352a370b178..28090e7cf59a4 100644
--- a/api_docs/kbn_core_fatal_errors_browser.mdx
+++ b/api_docs/kbn_core_fatal_errors_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-fatal-errors-browser
title: "@kbn/core-fatal-errors-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-fatal-errors-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-fatal-errors-browser']
---
import kbnCoreFatalErrorsBrowserObj from './kbn_core_fatal_errors_browser.devdocs.json';
diff --git a/api_docs/kbn_core_fatal_errors_browser_mocks.mdx b/api_docs/kbn_core_fatal_errors_browser_mocks.mdx
index d7bc0dcd525d6..de2cccb198719 100644
--- a/api_docs/kbn_core_fatal_errors_browser_mocks.mdx
+++ b/api_docs/kbn_core_fatal_errors_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-fatal-errors-browser-mocks
title: "@kbn/core-fatal-errors-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-fatal-errors-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-fatal-errors-browser-mocks']
---
import kbnCoreFatalErrorsBrowserMocksObj from './kbn_core_fatal_errors_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_feature_flags_browser.mdx b/api_docs/kbn_core_feature_flags_browser.mdx
index 8a1a7909b123c..943fda86e47ab 100644
--- a/api_docs/kbn_core_feature_flags_browser.mdx
+++ b/api_docs/kbn_core_feature_flags_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-feature-flags-browser
title: "@kbn/core-feature-flags-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-feature-flags-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-feature-flags-browser']
---
import kbnCoreFeatureFlagsBrowserObj from './kbn_core_feature_flags_browser.devdocs.json';
diff --git a/api_docs/kbn_core_feature_flags_browser_internal.mdx b/api_docs/kbn_core_feature_flags_browser_internal.mdx
index c4f4973c181c8..05be8f5d4dcd2 100644
--- a/api_docs/kbn_core_feature_flags_browser_internal.mdx
+++ b/api_docs/kbn_core_feature_flags_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-feature-flags-browser-internal
title: "@kbn/core-feature-flags-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-feature-flags-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-feature-flags-browser-internal']
---
import kbnCoreFeatureFlagsBrowserInternalObj from './kbn_core_feature_flags_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_feature_flags_browser_mocks.mdx b/api_docs/kbn_core_feature_flags_browser_mocks.mdx
index 206d7c0fb71f5..b6a92c92da5b1 100644
--- a/api_docs/kbn_core_feature_flags_browser_mocks.mdx
+++ b/api_docs/kbn_core_feature_flags_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-feature-flags-browser-mocks
title: "@kbn/core-feature-flags-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-feature-flags-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-feature-flags-browser-mocks']
---
import kbnCoreFeatureFlagsBrowserMocksObj from './kbn_core_feature_flags_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_feature_flags_server.mdx b/api_docs/kbn_core_feature_flags_server.mdx
index 3e21f8bd6fcd8..d99bc3d2c15a1 100644
--- a/api_docs/kbn_core_feature_flags_server.mdx
+++ b/api_docs/kbn_core_feature_flags_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-feature-flags-server
title: "@kbn/core-feature-flags-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-feature-flags-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-feature-flags-server']
---
import kbnCoreFeatureFlagsServerObj from './kbn_core_feature_flags_server.devdocs.json';
diff --git a/api_docs/kbn_core_feature_flags_server_internal.mdx b/api_docs/kbn_core_feature_flags_server_internal.mdx
index cf9537326591d..d1e046e60e94d 100644
--- a/api_docs/kbn_core_feature_flags_server_internal.mdx
+++ b/api_docs/kbn_core_feature_flags_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-feature-flags-server-internal
title: "@kbn/core-feature-flags-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-feature-flags-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-feature-flags-server-internal']
---
import kbnCoreFeatureFlagsServerInternalObj from './kbn_core_feature_flags_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_feature_flags_server_mocks.mdx b/api_docs/kbn_core_feature_flags_server_mocks.mdx
index 6272f6f168295..45a311d4aabd1 100644
--- a/api_docs/kbn_core_feature_flags_server_mocks.mdx
+++ b/api_docs/kbn_core_feature_flags_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-feature-flags-server-mocks
title: "@kbn/core-feature-flags-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-feature-flags-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-feature-flags-server-mocks']
---
import kbnCoreFeatureFlagsServerMocksObj from './kbn_core_feature_flags_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_http_browser.mdx b/api_docs/kbn_core_http_browser.mdx
index a6920eb6ddf65..03132a3e4b157 100644
--- a/api_docs/kbn_core_http_browser.mdx
+++ b/api_docs/kbn_core_http_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-browser
title: "@kbn/core-http-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-browser']
---
import kbnCoreHttpBrowserObj from './kbn_core_http_browser.devdocs.json';
diff --git a/api_docs/kbn_core_http_browser_internal.mdx b/api_docs/kbn_core_http_browser_internal.mdx
index 7ced7ee637605..97d25aa89d1ec 100644
--- a/api_docs/kbn_core_http_browser_internal.mdx
+++ b/api_docs/kbn_core_http_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-browser-internal
title: "@kbn/core-http-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-browser-internal']
---
import kbnCoreHttpBrowserInternalObj from './kbn_core_http_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_http_browser_mocks.mdx b/api_docs/kbn_core_http_browser_mocks.mdx
index 0f090b1f44645..bda77f088d868 100644
--- a/api_docs/kbn_core_http_browser_mocks.mdx
+++ b/api_docs/kbn_core_http_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-browser-mocks
title: "@kbn/core-http-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-browser-mocks']
---
import kbnCoreHttpBrowserMocksObj from './kbn_core_http_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_http_common.mdx b/api_docs/kbn_core_http_common.mdx
index 744ad532eb5fc..943f63f33b20b 100644
--- a/api_docs/kbn_core_http_common.mdx
+++ b/api_docs/kbn_core_http_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-common
title: "@kbn/core-http-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-common']
---
import kbnCoreHttpCommonObj from './kbn_core_http_common.devdocs.json';
diff --git a/api_docs/kbn_core_http_context_server_mocks.mdx b/api_docs/kbn_core_http_context_server_mocks.mdx
index 981afc8ac4f7c..b51310fcfb964 100644
--- a/api_docs/kbn_core_http_context_server_mocks.mdx
+++ b/api_docs/kbn_core_http_context_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-context-server-mocks
title: "@kbn/core-http-context-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-context-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-context-server-mocks']
---
import kbnCoreHttpContextServerMocksObj from './kbn_core_http_context_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_http_request_handler_context_server.mdx b/api_docs/kbn_core_http_request_handler_context_server.mdx
index 6cdfb482e861d..15d2dabf3618e 100644
--- a/api_docs/kbn_core_http_request_handler_context_server.mdx
+++ b/api_docs/kbn_core_http_request_handler_context_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-request-handler-context-server
title: "@kbn/core-http-request-handler-context-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-request-handler-context-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-request-handler-context-server']
---
import kbnCoreHttpRequestHandlerContextServerObj from './kbn_core_http_request_handler_context_server.devdocs.json';
diff --git a/api_docs/kbn_core_http_resources_server.mdx b/api_docs/kbn_core_http_resources_server.mdx
index 29bbdb934b434..cc20016d62ddf 100644
--- a/api_docs/kbn_core_http_resources_server.mdx
+++ b/api_docs/kbn_core_http_resources_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-resources-server
title: "@kbn/core-http-resources-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-resources-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-resources-server']
---
import kbnCoreHttpResourcesServerObj from './kbn_core_http_resources_server.devdocs.json';
diff --git a/api_docs/kbn_core_http_resources_server_internal.mdx b/api_docs/kbn_core_http_resources_server_internal.mdx
index bc039672a3799..b29be47eb284e 100644
--- a/api_docs/kbn_core_http_resources_server_internal.mdx
+++ b/api_docs/kbn_core_http_resources_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-resources-server-internal
title: "@kbn/core-http-resources-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-resources-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-resources-server-internal']
---
import kbnCoreHttpResourcesServerInternalObj from './kbn_core_http_resources_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_http_resources_server_mocks.mdx b/api_docs/kbn_core_http_resources_server_mocks.mdx
index b83dac397c0a0..4b1b2d9be6fd7 100644
--- a/api_docs/kbn_core_http_resources_server_mocks.mdx
+++ b/api_docs/kbn_core_http_resources_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-resources-server-mocks
title: "@kbn/core-http-resources-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-resources-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-resources-server-mocks']
---
import kbnCoreHttpResourcesServerMocksObj from './kbn_core_http_resources_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_http_router_server_internal.mdx b/api_docs/kbn_core_http_router_server_internal.mdx
index bc6c7cc0a00b3..aa077e10fe7cf 100644
--- a/api_docs/kbn_core_http_router_server_internal.mdx
+++ b/api_docs/kbn_core_http_router_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-router-server-internal
title: "@kbn/core-http-router-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-router-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-router-server-internal']
---
import kbnCoreHttpRouterServerInternalObj from './kbn_core_http_router_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_http_router_server_mocks.mdx b/api_docs/kbn_core_http_router_server_mocks.mdx
index 482931be61385..ce98db595acc8 100644
--- a/api_docs/kbn_core_http_router_server_mocks.mdx
+++ b/api_docs/kbn_core_http_router_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-router-server-mocks
title: "@kbn/core-http-router-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-router-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-router-server-mocks']
---
import kbnCoreHttpRouterServerMocksObj from './kbn_core_http_router_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_http_server.mdx b/api_docs/kbn_core_http_server.mdx
index 54e8b1e56bb97..d66f291bb585d 100644
--- a/api_docs/kbn_core_http_server.mdx
+++ b/api_docs/kbn_core_http_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-server
title: "@kbn/core-http-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-server']
---
import kbnCoreHttpServerObj from './kbn_core_http_server.devdocs.json';
diff --git a/api_docs/kbn_core_http_server_internal.mdx b/api_docs/kbn_core_http_server_internal.mdx
index 01df7bdc45cb1..068f94bbe00ef 100644
--- a/api_docs/kbn_core_http_server_internal.mdx
+++ b/api_docs/kbn_core_http_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-server-internal
title: "@kbn/core-http-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-server-internal']
---
import kbnCoreHttpServerInternalObj from './kbn_core_http_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_http_server_mocks.mdx b/api_docs/kbn_core_http_server_mocks.mdx
index bcf75282bd2aa..ecc556517e2fc 100644
--- a/api_docs/kbn_core_http_server_mocks.mdx
+++ b/api_docs/kbn_core_http_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-http-server-mocks
title: "@kbn/core-http-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-http-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-http-server-mocks']
---
import kbnCoreHttpServerMocksObj from './kbn_core_http_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_i18n_browser.mdx b/api_docs/kbn_core_i18n_browser.mdx
index 1958b62ca2aab..283642f2f2b48 100644
--- a/api_docs/kbn_core_i18n_browser.mdx
+++ b/api_docs/kbn_core_i18n_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-i18n-browser
title: "@kbn/core-i18n-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-i18n-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-i18n-browser']
---
import kbnCoreI18nBrowserObj from './kbn_core_i18n_browser.devdocs.json';
diff --git a/api_docs/kbn_core_i18n_browser_mocks.mdx b/api_docs/kbn_core_i18n_browser_mocks.mdx
index 0526670a2c5f0..164854b3360de 100644
--- a/api_docs/kbn_core_i18n_browser_mocks.mdx
+++ b/api_docs/kbn_core_i18n_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-i18n-browser-mocks
title: "@kbn/core-i18n-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-i18n-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-i18n-browser-mocks']
---
import kbnCoreI18nBrowserMocksObj from './kbn_core_i18n_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_i18n_server.mdx b/api_docs/kbn_core_i18n_server.mdx
index b8e0d10c02202..65aff06bba4e9 100644
--- a/api_docs/kbn_core_i18n_server.mdx
+++ b/api_docs/kbn_core_i18n_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-i18n-server
title: "@kbn/core-i18n-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-i18n-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-i18n-server']
---
import kbnCoreI18nServerObj from './kbn_core_i18n_server.devdocs.json';
diff --git a/api_docs/kbn_core_i18n_server_internal.mdx b/api_docs/kbn_core_i18n_server_internal.mdx
index cd37ff3b1262b..c156e63d9287b 100644
--- a/api_docs/kbn_core_i18n_server_internal.mdx
+++ b/api_docs/kbn_core_i18n_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-i18n-server-internal
title: "@kbn/core-i18n-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-i18n-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-i18n-server-internal']
---
import kbnCoreI18nServerInternalObj from './kbn_core_i18n_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_i18n_server_mocks.mdx b/api_docs/kbn_core_i18n_server_mocks.mdx
index e6cdc14376049..a248bd9aaa65c 100644
--- a/api_docs/kbn_core_i18n_server_mocks.mdx
+++ b/api_docs/kbn_core_i18n_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-i18n-server-mocks
title: "@kbn/core-i18n-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-i18n-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-i18n-server-mocks']
---
import kbnCoreI18nServerMocksObj from './kbn_core_i18n_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_injected_metadata_browser_mocks.mdx b/api_docs/kbn_core_injected_metadata_browser_mocks.mdx
index 3155155ac9ee8..b5dfa4950c432 100644
--- a/api_docs/kbn_core_injected_metadata_browser_mocks.mdx
+++ b/api_docs/kbn_core_injected_metadata_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-injected-metadata-browser-mocks
title: "@kbn/core-injected-metadata-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-injected-metadata-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-injected-metadata-browser-mocks']
---
import kbnCoreInjectedMetadataBrowserMocksObj from './kbn_core_injected_metadata_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_integrations_browser_internal.mdx b/api_docs/kbn_core_integrations_browser_internal.mdx
index 55a2168c01dac..92b229df0dea5 100644
--- a/api_docs/kbn_core_integrations_browser_internal.mdx
+++ b/api_docs/kbn_core_integrations_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-integrations-browser-internal
title: "@kbn/core-integrations-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-integrations-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-integrations-browser-internal']
---
import kbnCoreIntegrationsBrowserInternalObj from './kbn_core_integrations_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_integrations_browser_mocks.mdx b/api_docs/kbn_core_integrations_browser_mocks.mdx
index df4eea465313d..0f786cc3de74f 100644
--- a/api_docs/kbn_core_integrations_browser_mocks.mdx
+++ b/api_docs/kbn_core_integrations_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-integrations-browser-mocks
title: "@kbn/core-integrations-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-integrations-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-integrations-browser-mocks']
---
import kbnCoreIntegrationsBrowserMocksObj from './kbn_core_integrations_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_lifecycle_browser.mdx b/api_docs/kbn_core_lifecycle_browser.mdx
index caa1e7fd1881d..28aaf9c010d4a 100644
--- a/api_docs/kbn_core_lifecycle_browser.mdx
+++ b/api_docs/kbn_core_lifecycle_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-lifecycle-browser
title: "@kbn/core-lifecycle-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-lifecycle-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-lifecycle-browser']
---
import kbnCoreLifecycleBrowserObj from './kbn_core_lifecycle_browser.devdocs.json';
diff --git a/api_docs/kbn_core_lifecycle_browser_mocks.mdx b/api_docs/kbn_core_lifecycle_browser_mocks.mdx
index 192ee7d18e19b..098977edf8a45 100644
--- a/api_docs/kbn_core_lifecycle_browser_mocks.mdx
+++ b/api_docs/kbn_core_lifecycle_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-lifecycle-browser-mocks
title: "@kbn/core-lifecycle-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-lifecycle-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-lifecycle-browser-mocks']
---
import kbnCoreLifecycleBrowserMocksObj from './kbn_core_lifecycle_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_lifecycle_server.mdx b/api_docs/kbn_core_lifecycle_server.mdx
index 5e4caf846e724..62b17f1748670 100644
--- a/api_docs/kbn_core_lifecycle_server.mdx
+++ b/api_docs/kbn_core_lifecycle_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-lifecycle-server
title: "@kbn/core-lifecycle-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-lifecycle-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-lifecycle-server']
---
import kbnCoreLifecycleServerObj from './kbn_core_lifecycle_server.devdocs.json';
diff --git a/api_docs/kbn_core_lifecycle_server_mocks.mdx b/api_docs/kbn_core_lifecycle_server_mocks.mdx
index 1fca6e9c36937..6275fff69b2f4 100644
--- a/api_docs/kbn_core_lifecycle_server_mocks.mdx
+++ b/api_docs/kbn_core_lifecycle_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-lifecycle-server-mocks
title: "@kbn/core-lifecycle-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-lifecycle-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-lifecycle-server-mocks']
---
import kbnCoreLifecycleServerMocksObj from './kbn_core_lifecycle_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_logging_browser_mocks.mdx b/api_docs/kbn_core_logging_browser_mocks.mdx
index 8583929d38091..0548bd0822148 100644
--- a/api_docs/kbn_core_logging_browser_mocks.mdx
+++ b/api_docs/kbn_core_logging_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-logging-browser-mocks
title: "@kbn/core-logging-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-logging-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-logging-browser-mocks']
---
import kbnCoreLoggingBrowserMocksObj from './kbn_core_logging_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_logging_common_internal.mdx b/api_docs/kbn_core_logging_common_internal.mdx
index 8096d191d9866..2bcda4896adb1 100644
--- a/api_docs/kbn_core_logging_common_internal.mdx
+++ b/api_docs/kbn_core_logging_common_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-logging-common-internal
title: "@kbn/core-logging-common-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-logging-common-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-logging-common-internal']
---
import kbnCoreLoggingCommonInternalObj from './kbn_core_logging_common_internal.devdocs.json';
diff --git a/api_docs/kbn_core_logging_server.mdx b/api_docs/kbn_core_logging_server.mdx
index 3718b8cb45e20..d61fd8af32187 100644
--- a/api_docs/kbn_core_logging_server.mdx
+++ b/api_docs/kbn_core_logging_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-logging-server
title: "@kbn/core-logging-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-logging-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-logging-server']
---
import kbnCoreLoggingServerObj from './kbn_core_logging_server.devdocs.json';
diff --git a/api_docs/kbn_core_logging_server_internal.mdx b/api_docs/kbn_core_logging_server_internal.mdx
index e07ea38c9f71e..64e8ff2644f02 100644
--- a/api_docs/kbn_core_logging_server_internal.mdx
+++ b/api_docs/kbn_core_logging_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-logging-server-internal
title: "@kbn/core-logging-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-logging-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-logging-server-internal']
---
import kbnCoreLoggingServerInternalObj from './kbn_core_logging_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_logging_server_mocks.mdx b/api_docs/kbn_core_logging_server_mocks.mdx
index 68087b62c89a2..b6b19d625b9aa 100644
--- a/api_docs/kbn_core_logging_server_mocks.mdx
+++ b/api_docs/kbn_core_logging_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-logging-server-mocks
title: "@kbn/core-logging-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-logging-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-logging-server-mocks']
---
import kbnCoreLoggingServerMocksObj from './kbn_core_logging_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_metrics_collectors_server_internal.mdx b/api_docs/kbn_core_metrics_collectors_server_internal.mdx
index 1704c6cd854b1..c0343c3b6fba9 100644
--- a/api_docs/kbn_core_metrics_collectors_server_internal.mdx
+++ b/api_docs/kbn_core_metrics_collectors_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-metrics-collectors-server-internal
title: "@kbn/core-metrics-collectors-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-metrics-collectors-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-metrics-collectors-server-internal']
---
import kbnCoreMetricsCollectorsServerInternalObj from './kbn_core_metrics_collectors_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_metrics_collectors_server_mocks.mdx b/api_docs/kbn_core_metrics_collectors_server_mocks.mdx
index 38c1ac54e7408..ee592d1ea5aaf 100644
--- a/api_docs/kbn_core_metrics_collectors_server_mocks.mdx
+++ b/api_docs/kbn_core_metrics_collectors_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-metrics-collectors-server-mocks
title: "@kbn/core-metrics-collectors-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-metrics-collectors-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-metrics-collectors-server-mocks']
---
import kbnCoreMetricsCollectorsServerMocksObj from './kbn_core_metrics_collectors_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_metrics_server.mdx b/api_docs/kbn_core_metrics_server.mdx
index 425545965d273..f2bb56ef54648 100644
--- a/api_docs/kbn_core_metrics_server.mdx
+++ b/api_docs/kbn_core_metrics_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-metrics-server
title: "@kbn/core-metrics-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-metrics-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-metrics-server']
---
import kbnCoreMetricsServerObj from './kbn_core_metrics_server.devdocs.json';
diff --git a/api_docs/kbn_core_metrics_server_internal.mdx b/api_docs/kbn_core_metrics_server_internal.mdx
index eb8f9c0f20c89..39e77c9e29435 100644
--- a/api_docs/kbn_core_metrics_server_internal.mdx
+++ b/api_docs/kbn_core_metrics_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-metrics-server-internal
title: "@kbn/core-metrics-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-metrics-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-metrics-server-internal']
---
import kbnCoreMetricsServerInternalObj from './kbn_core_metrics_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_metrics_server_mocks.mdx b/api_docs/kbn_core_metrics_server_mocks.mdx
index 1abd9ce6ce6c4..87e3cfe6c8c54 100644
--- a/api_docs/kbn_core_metrics_server_mocks.mdx
+++ b/api_docs/kbn_core_metrics_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-metrics-server-mocks
title: "@kbn/core-metrics-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-metrics-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-metrics-server-mocks']
---
import kbnCoreMetricsServerMocksObj from './kbn_core_metrics_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_mount_utils_browser.mdx b/api_docs/kbn_core_mount_utils_browser.mdx
index 2e80a094e8df6..098e0c8ad5a1e 100644
--- a/api_docs/kbn_core_mount_utils_browser.mdx
+++ b/api_docs/kbn_core_mount_utils_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-mount-utils-browser
title: "@kbn/core-mount-utils-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-mount-utils-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-mount-utils-browser']
---
import kbnCoreMountUtilsBrowserObj from './kbn_core_mount_utils_browser.devdocs.json';
diff --git a/api_docs/kbn_core_node_server.mdx b/api_docs/kbn_core_node_server.mdx
index 9a62f5d98bc3e..ff21bdc820b1a 100644
--- a/api_docs/kbn_core_node_server.mdx
+++ b/api_docs/kbn_core_node_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-node-server
title: "@kbn/core-node-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-node-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-node-server']
---
import kbnCoreNodeServerObj from './kbn_core_node_server.devdocs.json';
diff --git a/api_docs/kbn_core_node_server_internal.mdx b/api_docs/kbn_core_node_server_internal.mdx
index b2e69f16f9015..053a64bd6939a 100644
--- a/api_docs/kbn_core_node_server_internal.mdx
+++ b/api_docs/kbn_core_node_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-node-server-internal
title: "@kbn/core-node-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-node-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-node-server-internal']
---
import kbnCoreNodeServerInternalObj from './kbn_core_node_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_node_server_mocks.mdx b/api_docs/kbn_core_node_server_mocks.mdx
index 0e0d3fa5b4d45..10d22bfc2e6b4 100644
--- a/api_docs/kbn_core_node_server_mocks.mdx
+++ b/api_docs/kbn_core_node_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-node-server-mocks
title: "@kbn/core-node-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-node-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-node-server-mocks']
---
import kbnCoreNodeServerMocksObj from './kbn_core_node_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_notifications_browser.mdx b/api_docs/kbn_core_notifications_browser.mdx
index 9c7390497c035..484067d042827 100644
--- a/api_docs/kbn_core_notifications_browser.mdx
+++ b/api_docs/kbn_core_notifications_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-notifications-browser
title: "@kbn/core-notifications-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-notifications-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-notifications-browser']
---
import kbnCoreNotificationsBrowserObj from './kbn_core_notifications_browser.devdocs.json';
diff --git a/api_docs/kbn_core_notifications_browser_internal.mdx b/api_docs/kbn_core_notifications_browser_internal.mdx
index a550e817ba969..2b03a50e949db 100644
--- a/api_docs/kbn_core_notifications_browser_internal.mdx
+++ b/api_docs/kbn_core_notifications_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-notifications-browser-internal
title: "@kbn/core-notifications-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-notifications-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-notifications-browser-internal']
---
import kbnCoreNotificationsBrowserInternalObj from './kbn_core_notifications_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_notifications_browser_mocks.mdx b/api_docs/kbn_core_notifications_browser_mocks.mdx
index 88ed391f355b0..26ee5cc8b67a1 100644
--- a/api_docs/kbn_core_notifications_browser_mocks.mdx
+++ b/api_docs/kbn_core_notifications_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-notifications-browser-mocks
title: "@kbn/core-notifications-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-notifications-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-notifications-browser-mocks']
---
import kbnCoreNotificationsBrowserMocksObj from './kbn_core_notifications_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_overlays_browser.mdx b/api_docs/kbn_core_overlays_browser.mdx
index 8f90b469cca71..7160b9f812de9 100644
--- a/api_docs/kbn_core_overlays_browser.mdx
+++ b/api_docs/kbn_core_overlays_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-overlays-browser
title: "@kbn/core-overlays-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-overlays-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-overlays-browser']
---
import kbnCoreOverlaysBrowserObj from './kbn_core_overlays_browser.devdocs.json';
diff --git a/api_docs/kbn_core_overlays_browser_internal.mdx b/api_docs/kbn_core_overlays_browser_internal.mdx
index ad029b117e1a0..89fe125006fc0 100644
--- a/api_docs/kbn_core_overlays_browser_internal.mdx
+++ b/api_docs/kbn_core_overlays_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-overlays-browser-internal
title: "@kbn/core-overlays-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-overlays-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-overlays-browser-internal']
---
import kbnCoreOverlaysBrowserInternalObj from './kbn_core_overlays_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_overlays_browser_mocks.mdx b/api_docs/kbn_core_overlays_browser_mocks.mdx
index de257fe40ed7a..e6c53bc690cd3 100644
--- a/api_docs/kbn_core_overlays_browser_mocks.mdx
+++ b/api_docs/kbn_core_overlays_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-overlays-browser-mocks
title: "@kbn/core-overlays-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-overlays-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-overlays-browser-mocks']
---
import kbnCoreOverlaysBrowserMocksObj from './kbn_core_overlays_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_plugins_browser.mdx b/api_docs/kbn_core_plugins_browser.mdx
index 5fa9cc1f1b86d..fc4ca4542d35e 100644
--- a/api_docs/kbn_core_plugins_browser.mdx
+++ b/api_docs/kbn_core_plugins_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-plugins-browser
title: "@kbn/core-plugins-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-plugins-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-plugins-browser']
---
import kbnCorePluginsBrowserObj from './kbn_core_plugins_browser.devdocs.json';
diff --git a/api_docs/kbn_core_plugins_browser_mocks.mdx b/api_docs/kbn_core_plugins_browser_mocks.mdx
index f8abda0565b2e..46d6217ac9089 100644
--- a/api_docs/kbn_core_plugins_browser_mocks.mdx
+++ b/api_docs/kbn_core_plugins_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-plugins-browser-mocks
title: "@kbn/core-plugins-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-plugins-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-plugins-browser-mocks']
---
import kbnCorePluginsBrowserMocksObj from './kbn_core_plugins_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_plugins_contracts_browser.mdx b/api_docs/kbn_core_plugins_contracts_browser.mdx
index 16af429bcaf84..27122580de4eb 100644
--- a/api_docs/kbn_core_plugins_contracts_browser.mdx
+++ b/api_docs/kbn_core_plugins_contracts_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-plugins-contracts-browser
title: "@kbn/core-plugins-contracts-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-plugins-contracts-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-plugins-contracts-browser']
---
import kbnCorePluginsContractsBrowserObj from './kbn_core_plugins_contracts_browser.devdocs.json';
diff --git a/api_docs/kbn_core_plugins_contracts_server.mdx b/api_docs/kbn_core_plugins_contracts_server.mdx
index 56c7749654ed0..5011ebb96f585 100644
--- a/api_docs/kbn_core_plugins_contracts_server.mdx
+++ b/api_docs/kbn_core_plugins_contracts_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-plugins-contracts-server
title: "@kbn/core-plugins-contracts-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-plugins-contracts-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-plugins-contracts-server']
---
import kbnCorePluginsContractsServerObj from './kbn_core_plugins_contracts_server.devdocs.json';
diff --git a/api_docs/kbn_core_plugins_server.mdx b/api_docs/kbn_core_plugins_server.mdx
index 8ed4f020bf5de..1f5e143f6e1bd 100644
--- a/api_docs/kbn_core_plugins_server.mdx
+++ b/api_docs/kbn_core_plugins_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-plugins-server
title: "@kbn/core-plugins-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-plugins-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-plugins-server']
---
import kbnCorePluginsServerObj from './kbn_core_plugins_server.devdocs.json';
diff --git a/api_docs/kbn_core_plugins_server_mocks.mdx b/api_docs/kbn_core_plugins_server_mocks.mdx
index 57d24f61d3ccd..4c78b095ec83a 100644
--- a/api_docs/kbn_core_plugins_server_mocks.mdx
+++ b/api_docs/kbn_core_plugins_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-plugins-server-mocks
title: "@kbn/core-plugins-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-plugins-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-plugins-server-mocks']
---
import kbnCorePluginsServerMocksObj from './kbn_core_plugins_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_preboot_server.mdx b/api_docs/kbn_core_preboot_server.mdx
index 6baf86200c164..e2bb1bf002b06 100644
--- a/api_docs/kbn_core_preboot_server.mdx
+++ b/api_docs/kbn_core_preboot_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-preboot-server
title: "@kbn/core-preboot-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-preboot-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-preboot-server']
---
import kbnCorePrebootServerObj from './kbn_core_preboot_server.devdocs.json';
diff --git a/api_docs/kbn_core_preboot_server_mocks.mdx b/api_docs/kbn_core_preboot_server_mocks.mdx
index f96c8be8b2564..b6d8f765bf1ab 100644
--- a/api_docs/kbn_core_preboot_server_mocks.mdx
+++ b/api_docs/kbn_core_preboot_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-preboot-server-mocks
title: "@kbn/core-preboot-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-preboot-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-preboot-server-mocks']
---
import kbnCorePrebootServerMocksObj from './kbn_core_preboot_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_rendering_browser_mocks.mdx b/api_docs/kbn_core_rendering_browser_mocks.mdx
index 01f32b83bcd3e..f7dbf554ad790 100644
--- a/api_docs/kbn_core_rendering_browser_mocks.mdx
+++ b/api_docs/kbn_core_rendering_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-rendering-browser-mocks
title: "@kbn/core-rendering-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-rendering-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-rendering-browser-mocks']
---
import kbnCoreRenderingBrowserMocksObj from './kbn_core_rendering_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_rendering_server_internal.mdx b/api_docs/kbn_core_rendering_server_internal.mdx
index 08dfff021b3c4..3715772deff10 100644
--- a/api_docs/kbn_core_rendering_server_internal.mdx
+++ b/api_docs/kbn_core_rendering_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-rendering-server-internal
title: "@kbn/core-rendering-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-rendering-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-rendering-server-internal']
---
import kbnCoreRenderingServerInternalObj from './kbn_core_rendering_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_rendering_server_mocks.mdx b/api_docs/kbn_core_rendering_server_mocks.mdx
index 7498aeeb2c51f..137eeaac82c12 100644
--- a/api_docs/kbn_core_rendering_server_mocks.mdx
+++ b/api_docs/kbn_core_rendering_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-rendering-server-mocks
title: "@kbn/core-rendering-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-rendering-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-rendering-server-mocks']
---
import kbnCoreRenderingServerMocksObj from './kbn_core_rendering_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_root_server_internal.mdx b/api_docs/kbn_core_root_server_internal.mdx
index b1b1062d223b1..70ae3a6a47cad 100644
--- a/api_docs/kbn_core_root_server_internal.mdx
+++ b/api_docs/kbn_core_root_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-root-server-internal
title: "@kbn/core-root-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-root-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-root-server-internal']
---
import kbnCoreRootServerInternalObj from './kbn_core_root_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_api_browser.mdx b/api_docs/kbn_core_saved_objects_api_browser.mdx
index 3e01385ae01dc..2b339e4c44843 100644
--- a/api_docs/kbn_core_saved_objects_api_browser.mdx
+++ b/api_docs/kbn_core_saved_objects_api_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-api-browser
title: "@kbn/core-saved-objects-api-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-api-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-api-browser']
---
import kbnCoreSavedObjectsApiBrowserObj from './kbn_core_saved_objects_api_browser.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_api_server.mdx b/api_docs/kbn_core_saved_objects_api_server.mdx
index f0b58ab87140f..4f939a18dce96 100644
--- a/api_docs/kbn_core_saved_objects_api_server.mdx
+++ b/api_docs/kbn_core_saved_objects_api_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-api-server
title: "@kbn/core-saved-objects-api-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-api-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-api-server']
---
import kbnCoreSavedObjectsApiServerObj from './kbn_core_saved_objects_api_server.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_api_server_mocks.mdx b/api_docs/kbn_core_saved_objects_api_server_mocks.mdx
index f1ad69bdb5bf1..c31fffac3c926 100644
--- a/api_docs/kbn_core_saved_objects_api_server_mocks.mdx
+++ b/api_docs/kbn_core_saved_objects_api_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-api-server-mocks
title: "@kbn/core-saved-objects-api-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-api-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-api-server-mocks']
---
import kbnCoreSavedObjectsApiServerMocksObj from './kbn_core_saved_objects_api_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_base_server_internal.mdx b/api_docs/kbn_core_saved_objects_base_server_internal.mdx
index 01c74065246f3..08e3a6feeb48c 100644
--- a/api_docs/kbn_core_saved_objects_base_server_internal.mdx
+++ b/api_docs/kbn_core_saved_objects_base_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-base-server-internal
title: "@kbn/core-saved-objects-base-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-base-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-base-server-internal']
---
import kbnCoreSavedObjectsBaseServerInternalObj from './kbn_core_saved_objects_base_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_base_server_mocks.mdx b/api_docs/kbn_core_saved_objects_base_server_mocks.mdx
index 270a77bec0dc6..62c25e8fb7f32 100644
--- a/api_docs/kbn_core_saved_objects_base_server_mocks.mdx
+++ b/api_docs/kbn_core_saved_objects_base_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-base-server-mocks
title: "@kbn/core-saved-objects-base-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-base-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-base-server-mocks']
---
import kbnCoreSavedObjectsBaseServerMocksObj from './kbn_core_saved_objects_base_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_browser.mdx b/api_docs/kbn_core_saved_objects_browser.mdx
index b5e98652848ac..82099920bc4c9 100644
--- a/api_docs/kbn_core_saved_objects_browser.mdx
+++ b/api_docs/kbn_core_saved_objects_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-browser
title: "@kbn/core-saved-objects-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-browser']
---
import kbnCoreSavedObjectsBrowserObj from './kbn_core_saved_objects_browser.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_browser_internal.mdx b/api_docs/kbn_core_saved_objects_browser_internal.mdx
index befe2f31005c3..e1539e36e123f 100644
--- a/api_docs/kbn_core_saved_objects_browser_internal.mdx
+++ b/api_docs/kbn_core_saved_objects_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-browser-internal
title: "@kbn/core-saved-objects-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-browser-internal']
---
import kbnCoreSavedObjectsBrowserInternalObj from './kbn_core_saved_objects_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_browser_mocks.mdx b/api_docs/kbn_core_saved_objects_browser_mocks.mdx
index df34f7aec728b..540e7067635b7 100644
--- a/api_docs/kbn_core_saved_objects_browser_mocks.mdx
+++ b/api_docs/kbn_core_saved_objects_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-browser-mocks
title: "@kbn/core-saved-objects-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-browser-mocks']
---
import kbnCoreSavedObjectsBrowserMocksObj from './kbn_core_saved_objects_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_common.mdx b/api_docs/kbn_core_saved_objects_common.mdx
index a8a90c6c12ebd..957e8e68d5708 100644
--- a/api_docs/kbn_core_saved_objects_common.mdx
+++ b/api_docs/kbn_core_saved_objects_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-common
title: "@kbn/core-saved-objects-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-common']
---
import kbnCoreSavedObjectsCommonObj from './kbn_core_saved_objects_common.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_import_export_server_internal.mdx b/api_docs/kbn_core_saved_objects_import_export_server_internal.mdx
index 306bc7ed415fe..2a49cf2566281 100644
--- a/api_docs/kbn_core_saved_objects_import_export_server_internal.mdx
+++ b/api_docs/kbn_core_saved_objects_import_export_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-import-export-server-internal
title: "@kbn/core-saved-objects-import-export-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-import-export-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-import-export-server-internal']
---
import kbnCoreSavedObjectsImportExportServerInternalObj from './kbn_core_saved_objects_import_export_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_import_export_server_mocks.mdx b/api_docs/kbn_core_saved_objects_import_export_server_mocks.mdx
index e3547de0277a5..4f9202273bca7 100644
--- a/api_docs/kbn_core_saved_objects_import_export_server_mocks.mdx
+++ b/api_docs/kbn_core_saved_objects_import_export_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-import-export-server-mocks
title: "@kbn/core-saved-objects-import-export-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-import-export-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-import-export-server-mocks']
---
import kbnCoreSavedObjectsImportExportServerMocksObj from './kbn_core_saved_objects_import_export_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_migration_server_internal.mdx b/api_docs/kbn_core_saved_objects_migration_server_internal.mdx
index 81fe4d01dda7c..61fe57dbcd799 100644
--- a/api_docs/kbn_core_saved_objects_migration_server_internal.mdx
+++ b/api_docs/kbn_core_saved_objects_migration_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-migration-server-internal
title: "@kbn/core-saved-objects-migration-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-migration-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-migration-server-internal']
---
import kbnCoreSavedObjectsMigrationServerInternalObj from './kbn_core_saved_objects_migration_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_migration_server_mocks.mdx b/api_docs/kbn_core_saved_objects_migration_server_mocks.mdx
index e80100108d6f2..71d7d1cc58655 100644
--- a/api_docs/kbn_core_saved_objects_migration_server_mocks.mdx
+++ b/api_docs/kbn_core_saved_objects_migration_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-migration-server-mocks
title: "@kbn/core-saved-objects-migration-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-migration-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-migration-server-mocks']
---
import kbnCoreSavedObjectsMigrationServerMocksObj from './kbn_core_saved_objects_migration_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_server.mdx b/api_docs/kbn_core_saved_objects_server.mdx
index 5343af44c81e5..86a4e387d702d 100644
--- a/api_docs/kbn_core_saved_objects_server.mdx
+++ b/api_docs/kbn_core_saved_objects_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-server
title: "@kbn/core-saved-objects-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-server']
---
import kbnCoreSavedObjectsServerObj from './kbn_core_saved_objects_server.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_server_internal.mdx b/api_docs/kbn_core_saved_objects_server_internal.mdx
index a9acdbe445f36..1923b7351f521 100644
--- a/api_docs/kbn_core_saved_objects_server_internal.mdx
+++ b/api_docs/kbn_core_saved_objects_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-server-internal
title: "@kbn/core-saved-objects-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-server-internal']
---
import kbnCoreSavedObjectsServerInternalObj from './kbn_core_saved_objects_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_server_mocks.mdx b/api_docs/kbn_core_saved_objects_server_mocks.mdx
index 3a5e8ffa74ccf..3e2491f52c291 100644
--- a/api_docs/kbn_core_saved_objects_server_mocks.mdx
+++ b/api_docs/kbn_core_saved_objects_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-server-mocks
title: "@kbn/core-saved-objects-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-server-mocks']
---
import kbnCoreSavedObjectsServerMocksObj from './kbn_core_saved_objects_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_saved_objects_utils_server.mdx b/api_docs/kbn_core_saved_objects_utils_server.mdx
index 6946fec6d292f..ace5594e319bb 100644
--- a/api_docs/kbn_core_saved_objects_utils_server.mdx
+++ b/api_docs/kbn_core_saved_objects_utils_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-saved-objects-utils-server
title: "@kbn/core-saved-objects-utils-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-saved-objects-utils-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-saved-objects-utils-server']
---
import kbnCoreSavedObjectsUtilsServerObj from './kbn_core_saved_objects_utils_server.devdocs.json';
diff --git a/api_docs/kbn_core_security_browser.mdx b/api_docs/kbn_core_security_browser.mdx
index 1dd4b8757e41f..0722fcdb1e641 100644
--- a/api_docs/kbn_core_security_browser.mdx
+++ b/api_docs/kbn_core_security_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-browser
title: "@kbn/core-security-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-browser']
---
import kbnCoreSecurityBrowserObj from './kbn_core_security_browser.devdocs.json';
diff --git a/api_docs/kbn_core_security_browser_internal.mdx b/api_docs/kbn_core_security_browser_internal.mdx
index addc4a4bbab85..28a7796bf86a0 100644
--- a/api_docs/kbn_core_security_browser_internal.mdx
+++ b/api_docs/kbn_core_security_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-browser-internal
title: "@kbn/core-security-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-browser-internal']
---
import kbnCoreSecurityBrowserInternalObj from './kbn_core_security_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_security_browser_mocks.mdx b/api_docs/kbn_core_security_browser_mocks.mdx
index 5977798eb397a..45f98c60ad917 100644
--- a/api_docs/kbn_core_security_browser_mocks.mdx
+++ b/api_docs/kbn_core_security_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-browser-mocks
title: "@kbn/core-security-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-browser-mocks']
---
import kbnCoreSecurityBrowserMocksObj from './kbn_core_security_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_security_common.mdx b/api_docs/kbn_core_security_common.mdx
index 3a676f691dc51..48a20821ec963 100644
--- a/api_docs/kbn_core_security_common.mdx
+++ b/api_docs/kbn_core_security_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-common
title: "@kbn/core-security-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-common']
---
import kbnCoreSecurityCommonObj from './kbn_core_security_common.devdocs.json';
diff --git a/api_docs/kbn_core_security_server.mdx b/api_docs/kbn_core_security_server.mdx
index 2c9aec5a95f4c..b0b8721fcbbcc 100644
--- a/api_docs/kbn_core_security_server.mdx
+++ b/api_docs/kbn_core_security_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-server
title: "@kbn/core-security-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-server']
---
import kbnCoreSecurityServerObj from './kbn_core_security_server.devdocs.json';
diff --git a/api_docs/kbn_core_security_server_internal.mdx b/api_docs/kbn_core_security_server_internal.mdx
index 1bb1bad8938ee..2b992a29cdb06 100644
--- a/api_docs/kbn_core_security_server_internal.mdx
+++ b/api_docs/kbn_core_security_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-server-internal
title: "@kbn/core-security-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-server-internal']
---
import kbnCoreSecurityServerInternalObj from './kbn_core_security_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_security_server_mocks.mdx b/api_docs/kbn_core_security_server_mocks.mdx
index 41f8fa6b030ba..8912f3027e1fc 100644
--- a/api_docs/kbn_core_security_server_mocks.mdx
+++ b/api_docs/kbn_core_security_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-security-server-mocks
title: "@kbn/core-security-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-security-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-security-server-mocks']
---
import kbnCoreSecurityServerMocksObj from './kbn_core_security_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_status_common.mdx b/api_docs/kbn_core_status_common.mdx
index c14690403b83d..019330ce8b4e2 100644
--- a/api_docs/kbn_core_status_common.mdx
+++ b/api_docs/kbn_core_status_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-status-common
title: "@kbn/core-status-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-status-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-status-common']
---
import kbnCoreStatusCommonObj from './kbn_core_status_common.devdocs.json';
diff --git a/api_docs/kbn_core_status_common_internal.mdx b/api_docs/kbn_core_status_common_internal.mdx
index a6a2a5efa828d..fd8118af20136 100644
--- a/api_docs/kbn_core_status_common_internal.mdx
+++ b/api_docs/kbn_core_status_common_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-status-common-internal
title: "@kbn/core-status-common-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-status-common-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-status-common-internal']
---
import kbnCoreStatusCommonInternalObj from './kbn_core_status_common_internal.devdocs.json';
diff --git a/api_docs/kbn_core_status_server.mdx b/api_docs/kbn_core_status_server.mdx
index d00a72e04a25d..b204af0082fa1 100644
--- a/api_docs/kbn_core_status_server.mdx
+++ b/api_docs/kbn_core_status_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-status-server
title: "@kbn/core-status-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-status-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-status-server']
---
import kbnCoreStatusServerObj from './kbn_core_status_server.devdocs.json';
diff --git a/api_docs/kbn_core_status_server_internal.mdx b/api_docs/kbn_core_status_server_internal.mdx
index 020f0cf9afc53..7164e942e4c1e 100644
--- a/api_docs/kbn_core_status_server_internal.mdx
+++ b/api_docs/kbn_core_status_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-status-server-internal
title: "@kbn/core-status-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-status-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-status-server-internal']
---
import kbnCoreStatusServerInternalObj from './kbn_core_status_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_status_server_mocks.mdx b/api_docs/kbn_core_status_server_mocks.mdx
index 8739984c6a093..be061ce19255b 100644
--- a/api_docs/kbn_core_status_server_mocks.mdx
+++ b/api_docs/kbn_core_status_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-status-server-mocks
title: "@kbn/core-status-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-status-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-status-server-mocks']
---
import kbnCoreStatusServerMocksObj from './kbn_core_status_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_test_helpers_deprecations_getters.mdx b/api_docs/kbn_core_test_helpers_deprecations_getters.mdx
index c4b43a71952c3..3e9f82e1e9519 100644
--- a/api_docs/kbn_core_test_helpers_deprecations_getters.mdx
+++ b/api_docs/kbn_core_test_helpers_deprecations_getters.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-test-helpers-deprecations-getters
title: "@kbn/core-test-helpers-deprecations-getters"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-test-helpers-deprecations-getters plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-test-helpers-deprecations-getters']
---
import kbnCoreTestHelpersDeprecationsGettersObj from './kbn_core_test_helpers_deprecations_getters.devdocs.json';
diff --git a/api_docs/kbn_core_test_helpers_http_setup_browser.mdx b/api_docs/kbn_core_test_helpers_http_setup_browser.mdx
index 62777d3cc8c3c..592ae6950991a 100644
--- a/api_docs/kbn_core_test_helpers_http_setup_browser.mdx
+++ b/api_docs/kbn_core_test_helpers_http_setup_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-test-helpers-http-setup-browser
title: "@kbn/core-test-helpers-http-setup-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-test-helpers-http-setup-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-test-helpers-http-setup-browser']
---
import kbnCoreTestHelpersHttpSetupBrowserObj from './kbn_core_test_helpers_http_setup_browser.devdocs.json';
diff --git a/api_docs/kbn_core_test_helpers_kbn_server.mdx b/api_docs/kbn_core_test_helpers_kbn_server.mdx
index 1b269882a56b0..04ab1b7b18ec5 100644
--- a/api_docs/kbn_core_test_helpers_kbn_server.mdx
+++ b/api_docs/kbn_core_test_helpers_kbn_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-test-helpers-kbn-server
title: "@kbn/core-test-helpers-kbn-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-test-helpers-kbn-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-test-helpers-kbn-server']
---
import kbnCoreTestHelpersKbnServerObj from './kbn_core_test_helpers_kbn_server.devdocs.json';
diff --git a/api_docs/kbn_core_test_helpers_model_versions.mdx b/api_docs/kbn_core_test_helpers_model_versions.mdx
index f0d2e79c67c1c..f4ed2c8404b4e 100644
--- a/api_docs/kbn_core_test_helpers_model_versions.mdx
+++ b/api_docs/kbn_core_test_helpers_model_versions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-test-helpers-model-versions
title: "@kbn/core-test-helpers-model-versions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-test-helpers-model-versions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-test-helpers-model-versions']
---
import kbnCoreTestHelpersModelVersionsObj from './kbn_core_test_helpers_model_versions.devdocs.json';
diff --git a/api_docs/kbn_core_test_helpers_so_type_serializer.mdx b/api_docs/kbn_core_test_helpers_so_type_serializer.mdx
index 788dccd889d2b..8a54ec213d267 100644
--- a/api_docs/kbn_core_test_helpers_so_type_serializer.mdx
+++ b/api_docs/kbn_core_test_helpers_so_type_serializer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-test-helpers-so-type-serializer
title: "@kbn/core-test-helpers-so-type-serializer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-test-helpers-so-type-serializer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-test-helpers-so-type-serializer']
---
import kbnCoreTestHelpersSoTypeSerializerObj from './kbn_core_test_helpers_so_type_serializer.devdocs.json';
diff --git a/api_docs/kbn_core_test_helpers_test_utils.mdx b/api_docs/kbn_core_test_helpers_test_utils.mdx
index 6e661178498c5..9d20649a27ed6 100644
--- a/api_docs/kbn_core_test_helpers_test_utils.mdx
+++ b/api_docs/kbn_core_test_helpers_test_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-test-helpers-test-utils
title: "@kbn/core-test-helpers-test-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-test-helpers-test-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-test-helpers-test-utils']
---
import kbnCoreTestHelpersTestUtilsObj from './kbn_core_test_helpers_test_utils.devdocs.json';
diff --git a/api_docs/kbn_core_theme_browser.mdx b/api_docs/kbn_core_theme_browser.mdx
index 09c794367a054..89c8cf61efda4 100644
--- a/api_docs/kbn_core_theme_browser.mdx
+++ b/api_docs/kbn_core_theme_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-theme-browser
title: "@kbn/core-theme-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-theme-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-theme-browser']
---
import kbnCoreThemeBrowserObj from './kbn_core_theme_browser.devdocs.json';
diff --git a/api_docs/kbn_core_theme_browser_mocks.mdx b/api_docs/kbn_core_theme_browser_mocks.mdx
index 93f189c32efb3..e3260e79a6ca2 100644
--- a/api_docs/kbn_core_theme_browser_mocks.mdx
+++ b/api_docs/kbn_core_theme_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-theme-browser-mocks
title: "@kbn/core-theme-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-theme-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-theme-browser-mocks']
---
import kbnCoreThemeBrowserMocksObj from './kbn_core_theme_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_browser.mdx b/api_docs/kbn_core_ui_settings_browser.mdx
index 9f4143018aea7..c6cd54c6e6ebb 100644
--- a/api_docs/kbn_core_ui_settings_browser.mdx
+++ b/api_docs/kbn_core_ui_settings_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-browser
title: "@kbn/core-ui-settings-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-browser']
---
import kbnCoreUiSettingsBrowserObj from './kbn_core_ui_settings_browser.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_browser_internal.mdx b/api_docs/kbn_core_ui_settings_browser_internal.mdx
index dff3f12c602cb..92c1ca6525a70 100644
--- a/api_docs/kbn_core_ui_settings_browser_internal.mdx
+++ b/api_docs/kbn_core_ui_settings_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-browser-internal
title: "@kbn/core-ui-settings-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-browser-internal']
---
import kbnCoreUiSettingsBrowserInternalObj from './kbn_core_ui_settings_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_browser_mocks.mdx b/api_docs/kbn_core_ui_settings_browser_mocks.mdx
index fb8e0fa379d04..cc55590ffedae 100644
--- a/api_docs/kbn_core_ui_settings_browser_mocks.mdx
+++ b/api_docs/kbn_core_ui_settings_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-browser-mocks
title: "@kbn/core-ui-settings-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-browser-mocks']
---
import kbnCoreUiSettingsBrowserMocksObj from './kbn_core_ui_settings_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_common.mdx b/api_docs/kbn_core_ui_settings_common.mdx
index 8caa81ca8dca8..f2b79c56583dc 100644
--- a/api_docs/kbn_core_ui_settings_common.mdx
+++ b/api_docs/kbn_core_ui_settings_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-common
title: "@kbn/core-ui-settings-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-common']
---
import kbnCoreUiSettingsCommonObj from './kbn_core_ui_settings_common.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_server.mdx b/api_docs/kbn_core_ui_settings_server.mdx
index 32b17effcc75c..6d082b2682f93 100644
--- a/api_docs/kbn_core_ui_settings_server.mdx
+++ b/api_docs/kbn_core_ui_settings_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-server
title: "@kbn/core-ui-settings-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-server']
---
import kbnCoreUiSettingsServerObj from './kbn_core_ui_settings_server.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_server_internal.mdx b/api_docs/kbn_core_ui_settings_server_internal.mdx
index 420b76f35c986..b3ba2a52becac 100644
--- a/api_docs/kbn_core_ui_settings_server_internal.mdx
+++ b/api_docs/kbn_core_ui_settings_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-server-internal
title: "@kbn/core-ui-settings-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-server-internal']
---
import kbnCoreUiSettingsServerInternalObj from './kbn_core_ui_settings_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_ui_settings_server_mocks.mdx b/api_docs/kbn_core_ui_settings_server_mocks.mdx
index 27634aeec3b1a..a9fe942e27204 100644
--- a/api_docs/kbn_core_ui_settings_server_mocks.mdx
+++ b/api_docs/kbn_core_ui_settings_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-ui-settings-server-mocks
title: "@kbn/core-ui-settings-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-ui-settings-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-ui-settings-server-mocks']
---
import kbnCoreUiSettingsServerMocksObj from './kbn_core_ui_settings_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_usage_data_server.mdx b/api_docs/kbn_core_usage_data_server.mdx
index 950563ec7283f..73f49ac82e5e1 100644
--- a/api_docs/kbn_core_usage_data_server.mdx
+++ b/api_docs/kbn_core_usage_data_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-usage-data-server
title: "@kbn/core-usage-data-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-usage-data-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-usage-data-server']
---
import kbnCoreUsageDataServerObj from './kbn_core_usage_data_server.devdocs.json';
diff --git a/api_docs/kbn_core_usage_data_server_internal.mdx b/api_docs/kbn_core_usage_data_server_internal.mdx
index 8d193dc9aec3f..bff1e20b3b2c7 100644
--- a/api_docs/kbn_core_usage_data_server_internal.mdx
+++ b/api_docs/kbn_core_usage_data_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-usage-data-server-internal
title: "@kbn/core-usage-data-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-usage-data-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-usage-data-server-internal']
---
import kbnCoreUsageDataServerInternalObj from './kbn_core_usage_data_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_usage_data_server_mocks.mdx b/api_docs/kbn_core_usage_data_server_mocks.mdx
index fc9662ebc78d6..0a99a56360b49 100644
--- a/api_docs/kbn_core_usage_data_server_mocks.mdx
+++ b/api_docs/kbn_core_usage_data_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-usage-data-server-mocks
title: "@kbn/core-usage-data-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-usage-data-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-usage-data-server-mocks']
---
import kbnCoreUsageDataServerMocksObj from './kbn_core_usage_data_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_browser.mdx b/api_docs/kbn_core_user_profile_browser.mdx
index c8abf721f56e9..4b29672ce3507 100644
--- a/api_docs/kbn_core_user_profile_browser.mdx
+++ b/api_docs/kbn_core_user_profile_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-browser
title: "@kbn/core-user-profile-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-browser']
---
import kbnCoreUserProfileBrowserObj from './kbn_core_user_profile_browser.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_browser_internal.mdx b/api_docs/kbn_core_user_profile_browser_internal.mdx
index b78d669b45c9c..9369a3205c419 100644
--- a/api_docs/kbn_core_user_profile_browser_internal.mdx
+++ b/api_docs/kbn_core_user_profile_browser_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-browser-internal
title: "@kbn/core-user-profile-browser-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-browser-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-browser-internal']
---
import kbnCoreUserProfileBrowserInternalObj from './kbn_core_user_profile_browser_internal.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_browser_mocks.mdx b/api_docs/kbn_core_user_profile_browser_mocks.mdx
index 6e447d20ec98f..9fd50a9d48af0 100644
--- a/api_docs/kbn_core_user_profile_browser_mocks.mdx
+++ b/api_docs/kbn_core_user_profile_browser_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-browser-mocks
title: "@kbn/core-user-profile-browser-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-browser-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-browser-mocks']
---
import kbnCoreUserProfileBrowserMocksObj from './kbn_core_user_profile_browser_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_common.mdx b/api_docs/kbn_core_user_profile_common.mdx
index e3c40a58d441b..3bdb0b47cf9e7 100644
--- a/api_docs/kbn_core_user_profile_common.mdx
+++ b/api_docs/kbn_core_user_profile_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-common
title: "@kbn/core-user-profile-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-common']
---
import kbnCoreUserProfileCommonObj from './kbn_core_user_profile_common.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_server.mdx b/api_docs/kbn_core_user_profile_server.mdx
index 15b9313ad5701..9d6505a559bf7 100644
--- a/api_docs/kbn_core_user_profile_server.mdx
+++ b/api_docs/kbn_core_user_profile_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-server
title: "@kbn/core-user-profile-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-server']
---
import kbnCoreUserProfileServerObj from './kbn_core_user_profile_server.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_server_internal.mdx b/api_docs/kbn_core_user_profile_server_internal.mdx
index 8756e4f211c1a..ffcd6cfd2fab4 100644
--- a/api_docs/kbn_core_user_profile_server_internal.mdx
+++ b/api_docs/kbn_core_user_profile_server_internal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-server-internal
title: "@kbn/core-user-profile-server-internal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-server-internal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-server-internal']
---
import kbnCoreUserProfileServerInternalObj from './kbn_core_user_profile_server_internal.devdocs.json';
diff --git a/api_docs/kbn_core_user_profile_server_mocks.mdx b/api_docs/kbn_core_user_profile_server_mocks.mdx
index c69dfca4fbe96..6eca7a76b7261 100644
--- a/api_docs/kbn_core_user_profile_server_mocks.mdx
+++ b/api_docs/kbn_core_user_profile_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-profile-server-mocks
title: "@kbn/core-user-profile-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-profile-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-profile-server-mocks']
---
import kbnCoreUserProfileServerMocksObj from './kbn_core_user_profile_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_core_user_settings_server.mdx b/api_docs/kbn_core_user_settings_server.mdx
index 76d4a0a9a31c9..312191eaae0b2 100644
--- a/api_docs/kbn_core_user_settings_server.mdx
+++ b/api_docs/kbn_core_user_settings_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-settings-server
title: "@kbn/core-user-settings-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-settings-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-settings-server']
---
import kbnCoreUserSettingsServerObj from './kbn_core_user_settings_server.devdocs.json';
diff --git a/api_docs/kbn_core_user_settings_server_mocks.mdx b/api_docs/kbn_core_user_settings_server_mocks.mdx
index 19a007e1ae14c..ceb76aae74ec1 100644
--- a/api_docs/kbn_core_user_settings_server_mocks.mdx
+++ b/api_docs/kbn_core_user_settings_server_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-core-user-settings-server-mocks
title: "@kbn/core-user-settings-server-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/core-user-settings-server-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/core-user-settings-server-mocks']
---
import kbnCoreUserSettingsServerMocksObj from './kbn_core_user_settings_server_mocks.devdocs.json';
diff --git a/api_docs/kbn_crypto.mdx b/api_docs/kbn_crypto.mdx
index bd8195f213008..d36ff18b0bde5 100644
--- a/api_docs/kbn_crypto.mdx
+++ b/api_docs/kbn_crypto.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-crypto
title: "@kbn/crypto"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/crypto plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/crypto']
---
import kbnCryptoObj from './kbn_crypto.devdocs.json';
diff --git a/api_docs/kbn_crypto_browser.mdx b/api_docs/kbn_crypto_browser.mdx
index 07f6bba625206..d7ab72aee0d1b 100644
--- a/api_docs/kbn_crypto_browser.mdx
+++ b/api_docs/kbn_crypto_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-crypto-browser
title: "@kbn/crypto-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/crypto-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/crypto-browser']
---
import kbnCryptoBrowserObj from './kbn_crypto_browser.devdocs.json';
diff --git a/api_docs/kbn_custom_icons.mdx b/api_docs/kbn_custom_icons.mdx
index 9fc2a4fec3ed4..b7994dcc55b53 100644
--- a/api_docs/kbn_custom_icons.mdx
+++ b/api_docs/kbn_custom_icons.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-custom-icons
title: "@kbn/custom-icons"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/custom-icons plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/custom-icons']
---
import kbnCustomIconsObj from './kbn_custom_icons.devdocs.json';
diff --git a/api_docs/kbn_custom_integrations.mdx b/api_docs/kbn_custom_integrations.mdx
index 20643ac1a6df8..d7764fc6ad71b 100644
--- a/api_docs/kbn_custom_integrations.mdx
+++ b/api_docs/kbn_custom_integrations.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-custom-integrations
title: "@kbn/custom-integrations"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/custom-integrations plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/custom-integrations']
---
import kbnCustomIntegrationsObj from './kbn_custom_integrations.devdocs.json';
diff --git a/api_docs/kbn_cypress_config.mdx b/api_docs/kbn_cypress_config.mdx
index a1060beaa0e4f..bd23f94d999ed 100644
--- a/api_docs/kbn_cypress_config.mdx
+++ b/api_docs/kbn_cypress_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-cypress-config
title: "@kbn/cypress-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/cypress-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cypress-config']
---
import kbnCypressConfigObj from './kbn_cypress_config.devdocs.json';
diff --git a/api_docs/kbn_data_forge.mdx b/api_docs/kbn_data_forge.mdx
index dc098d89e505d..dcec7e4697df9 100644
--- a/api_docs/kbn_data_forge.mdx
+++ b/api_docs/kbn_data_forge.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-data-forge
title: "@kbn/data-forge"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/data-forge plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/data-forge']
---
import kbnDataForgeObj from './kbn_data_forge.devdocs.json';
diff --git a/api_docs/kbn_data_service.mdx b/api_docs/kbn_data_service.mdx
index 1f70d0557fa47..89b7eefc7d821 100644
--- a/api_docs/kbn_data_service.mdx
+++ b/api_docs/kbn_data_service.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-data-service
title: "@kbn/data-service"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/data-service plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/data-service']
---
import kbnDataServiceObj from './kbn_data_service.devdocs.json';
diff --git a/api_docs/kbn_data_stream_adapter.mdx b/api_docs/kbn_data_stream_adapter.mdx
index 2944a00dbfc8d..53bc517415b12 100644
--- a/api_docs/kbn_data_stream_adapter.mdx
+++ b/api_docs/kbn_data_stream_adapter.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-data-stream-adapter
title: "@kbn/data-stream-adapter"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/data-stream-adapter plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/data-stream-adapter']
---
import kbnDataStreamAdapterObj from './kbn_data_stream_adapter.devdocs.json';
diff --git a/api_docs/kbn_data_view_utils.mdx b/api_docs/kbn_data_view_utils.mdx
index dc562b97127aa..f0755cb6b1ba9 100644
--- a/api_docs/kbn_data_view_utils.mdx
+++ b/api_docs/kbn_data_view_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-data-view-utils
title: "@kbn/data-view-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/data-view-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/data-view-utils']
---
import kbnDataViewUtilsObj from './kbn_data_view_utils.devdocs.json';
diff --git a/api_docs/kbn_datemath.mdx b/api_docs/kbn_datemath.mdx
index 00a310c21d93a..fca00527a69f3 100644
--- a/api_docs/kbn_datemath.mdx
+++ b/api_docs/kbn_datemath.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-datemath
title: "@kbn/datemath"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/datemath plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/datemath']
---
import kbnDatemathObj from './kbn_datemath.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_analytics.mdx b/api_docs/kbn_deeplinks_analytics.mdx
index bd312e44081c0..a344680bc8365 100644
--- a/api_docs/kbn_deeplinks_analytics.mdx
+++ b/api_docs/kbn_deeplinks_analytics.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-analytics
title: "@kbn/deeplinks-analytics"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-analytics plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-analytics']
---
import kbnDeeplinksAnalyticsObj from './kbn_deeplinks_analytics.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_devtools.mdx b/api_docs/kbn_deeplinks_devtools.mdx
index 6430e6bb0c0c6..7b69bf1deebbc 100644
--- a/api_docs/kbn_deeplinks_devtools.mdx
+++ b/api_docs/kbn_deeplinks_devtools.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-devtools
title: "@kbn/deeplinks-devtools"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-devtools plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-devtools']
---
import kbnDeeplinksDevtoolsObj from './kbn_deeplinks_devtools.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_fleet.mdx b/api_docs/kbn_deeplinks_fleet.mdx
index 08680d4b79bcb..1edfd7222fefa 100644
--- a/api_docs/kbn_deeplinks_fleet.mdx
+++ b/api_docs/kbn_deeplinks_fleet.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-fleet
title: "@kbn/deeplinks-fleet"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-fleet plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-fleet']
---
import kbnDeeplinksFleetObj from './kbn_deeplinks_fleet.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_management.mdx b/api_docs/kbn_deeplinks_management.mdx
index 84f1d68d79465..c6dc83e676cfb 100644
--- a/api_docs/kbn_deeplinks_management.mdx
+++ b/api_docs/kbn_deeplinks_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-management
title: "@kbn/deeplinks-management"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-management plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-management']
---
import kbnDeeplinksManagementObj from './kbn_deeplinks_management.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_ml.mdx b/api_docs/kbn_deeplinks_ml.mdx
index 3ae7e87a4eca2..556124633ad3a 100644
--- a/api_docs/kbn_deeplinks_ml.mdx
+++ b/api_docs/kbn_deeplinks_ml.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-ml
title: "@kbn/deeplinks-ml"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-ml plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-ml']
---
import kbnDeeplinksMlObj from './kbn_deeplinks_ml.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_observability.mdx b/api_docs/kbn_deeplinks_observability.mdx
index 23500c0e0b48c..49f102e3d3fd0 100644
--- a/api_docs/kbn_deeplinks_observability.mdx
+++ b/api_docs/kbn_deeplinks_observability.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-observability
title: "@kbn/deeplinks-observability"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-observability plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-observability']
---
import kbnDeeplinksObservabilityObj from './kbn_deeplinks_observability.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_search.mdx b/api_docs/kbn_deeplinks_search.mdx
index 0df1fe5391c83..4662c3e0fc212 100644
--- a/api_docs/kbn_deeplinks_search.mdx
+++ b/api_docs/kbn_deeplinks_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-search
title: "@kbn/deeplinks-search"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-search plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-search']
---
import kbnDeeplinksSearchObj from './kbn_deeplinks_search.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_security.mdx b/api_docs/kbn_deeplinks_security.mdx
index d2d4888644ece..f5956cbe3a9da 100644
--- a/api_docs/kbn_deeplinks_security.mdx
+++ b/api_docs/kbn_deeplinks_security.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-security
title: "@kbn/deeplinks-security"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-security plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-security']
---
import kbnDeeplinksSecurityObj from './kbn_deeplinks_security.devdocs.json';
diff --git a/api_docs/kbn_deeplinks_shared.mdx b/api_docs/kbn_deeplinks_shared.mdx
index 728dc7a9081a5..4f502cc5a292d 100644
--- a/api_docs/kbn_deeplinks_shared.mdx
+++ b/api_docs/kbn_deeplinks_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-deeplinks-shared
title: "@kbn/deeplinks-shared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/deeplinks-shared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/deeplinks-shared']
---
import kbnDeeplinksSharedObj from './kbn_deeplinks_shared.devdocs.json';
diff --git a/api_docs/kbn_default_nav_analytics.mdx b/api_docs/kbn_default_nav_analytics.mdx
index f4053093af927..d3e2983b1986f 100644
--- a/api_docs/kbn_default_nav_analytics.mdx
+++ b/api_docs/kbn_default_nav_analytics.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-default-nav-analytics
title: "@kbn/default-nav-analytics"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/default-nav-analytics plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/default-nav-analytics']
---
import kbnDefaultNavAnalyticsObj from './kbn_default_nav_analytics.devdocs.json';
diff --git a/api_docs/kbn_default_nav_devtools.mdx b/api_docs/kbn_default_nav_devtools.mdx
index a4e5153898fc9..5efd56de2d99b 100644
--- a/api_docs/kbn_default_nav_devtools.mdx
+++ b/api_docs/kbn_default_nav_devtools.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-default-nav-devtools
title: "@kbn/default-nav-devtools"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/default-nav-devtools plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/default-nav-devtools']
---
import kbnDefaultNavDevtoolsObj from './kbn_default_nav_devtools.devdocs.json';
diff --git a/api_docs/kbn_default_nav_management.mdx b/api_docs/kbn_default_nav_management.mdx
index a163c0649fde4..10fb9a69dd148 100644
--- a/api_docs/kbn_default_nav_management.mdx
+++ b/api_docs/kbn_default_nav_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-default-nav-management
title: "@kbn/default-nav-management"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/default-nav-management plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/default-nav-management']
---
import kbnDefaultNavManagementObj from './kbn_default_nav_management.devdocs.json';
diff --git a/api_docs/kbn_default_nav_ml.mdx b/api_docs/kbn_default_nav_ml.mdx
index af9ce151fce7d..5e90d50571f50 100644
--- a/api_docs/kbn_default_nav_ml.mdx
+++ b/api_docs/kbn_default_nav_ml.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-default-nav-ml
title: "@kbn/default-nav-ml"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/default-nav-ml plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/default-nav-ml']
---
import kbnDefaultNavMlObj from './kbn_default_nav_ml.devdocs.json';
diff --git a/api_docs/kbn_dev_cli_errors.mdx b/api_docs/kbn_dev_cli_errors.mdx
index 9d00139f52155..82961d44d2252 100644
--- a/api_docs/kbn_dev_cli_errors.mdx
+++ b/api_docs/kbn_dev_cli_errors.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-dev-cli-errors
title: "@kbn/dev-cli-errors"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/dev-cli-errors plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/dev-cli-errors']
---
import kbnDevCliErrorsObj from './kbn_dev_cli_errors.devdocs.json';
diff --git a/api_docs/kbn_dev_cli_runner.mdx b/api_docs/kbn_dev_cli_runner.mdx
index f9b3f74819038..d3a1af810206c 100644
--- a/api_docs/kbn_dev_cli_runner.mdx
+++ b/api_docs/kbn_dev_cli_runner.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-dev-cli-runner
title: "@kbn/dev-cli-runner"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/dev-cli-runner plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/dev-cli-runner']
---
import kbnDevCliRunnerObj from './kbn_dev_cli_runner.devdocs.json';
diff --git a/api_docs/kbn_dev_proc_runner.mdx b/api_docs/kbn_dev_proc_runner.mdx
index 298c11aee5cd0..f34f24b583378 100644
--- a/api_docs/kbn_dev_proc_runner.mdx
+++ b/api_docs/kbn_dev_proc_runner.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-dev-proc-runner
title: "@kbn/dev-proc-runner"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/dev-proc-runner plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/dev-proc-runner']
---
import kbnDevProcRunnerObj from './kbn_dev_proc_runner.devdocs.json';
diff --git a/api_docs/kbn_dev_utils.mdx b/api_docs/kbn_dev_utils.mdx
index 8d494c1b89ff9..580681eed680d 100644
--- a/api_docs/kbn_dev_utils.mdx
+++ b/api_docs/kbn_dev_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-dev-utils
title: "@kbn/dev-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/dev-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/dev-utils']
---
import kbnDevUtilsObj from './kbn_dev_utils.devdocs.json';
diff --git a/api_docs/kbn_discover_contextual_components.mdx b/api_docs/kbn_discover_contextual_components.mdx
index 605178f039766..09a6450ebccdb 100644
--- a/api_docs/kbn_discover_contextual_components.mdx
+++ b/api_docs/kbn_discover_contextual_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-discover-contextual-components
title: "@kbn/discover-contextual-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/discover-contextual-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/discover-contextual-components']
---
import kbnDiscoverContextualComponentsObj from './kbn_discover_contextual_components.devdocs.json';
diff --git a/api_docs/kbn_discover_utils.mdx b/api_docs/kbn_discover_utils.mdx
index cc680344ea6c8..e76ff611434e4 100644
--- a/api_docs/kbn_discover_utils.mdx
+++ b/api_docs/kbn_discover_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-discover-utils
title: "@kbn/discover-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/discover-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/discover-utils']
---
import kbnDiscoverUtilsObj from './kbn_discover_utils.devdocs.json';
diff --git a/api_docs/kbn_doc_links.mdx b/api_docs/kbn_doc_links.mdx
index c44b7c18dd074..43b0a0bd2c15d 100644
--- a/api_docs/kbn_doc_links.mdx
+++ b/api_docs/kbn_doc_links.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-doc-links
title: "@kbn/doc-links"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/doc-links plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/doc-links']
---
import kbnDocLinksObj from './kbn_doc_links.devdocs.json';
diff --git a/api_docs/kbn_docs_utils.mdx b/api_docs/kbn_docs_utils.mdx
index b27008e251054..20e9fadae1598 100644
--- a/api_docs/kbn_docs_utils.mdx
+++ b/api_docs/kbn_docs_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-docs-utils
title: "@kbn/docs-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/docs-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/docs-utils']
---
import kbnDocsUtilsObj from './kbn_docs_utils.devdocs.json';
diff --git a/api_docs/kbn_dom_drag_drop.mdx b/api_docs/kbn_dom_drag_drop.mdx
index 20b062a76fff6..70ea7afd79dfc 100644
--- a/api_docs/kbn_dom_drag_drop.mdx
+++ b/api_docs/kbn_dom_drag_drop.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-dom-drag-drop
title: "@kbn/dom-drag-drop"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/dom-drag-drop plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/dom-drag-drop']
---
import kbnDomDragDropObj from './kbn_dom_drag_drop.devdocs.json';
diff --git a/api_docs/kbn_ebt_tools.mdx b/api_docs/kbn_ebt_tools.mdx
index 85c4504f7fc0c..5f2b72ef8a732 100644
--- a/api_docs/kbn_ebt_tools.mdx
+++ b/api_docs/kbn_ebt_tools.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ebt-tools
title: "@kbn/ebt-tools"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ebt-tools plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ebt-tools']
---
import kbnEbtToolsObj from './kbn_ebt_tools.devdocs.json';
diff --git a/api_docs/kbn_ecs_data_quality_dashboard.mdx b/api_docs/kbn_ecs_data_quality_dashboard.mdx
index d9aa87437e71f..b642bd3857f78 100644
--- a/api_docs/kbn_ecs_data_quality_dashboard.mdx
+++ b/api_docs/kbn_ecs_data_quality_dashboard.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ecs-data-quality-dashboard
title: "@kbn/ecs-data-quality-dashboard"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ecs-data-quality-dashboard plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ecs-data-quality-dashboard']
---
import kbnEcsDataQualityDashboardObj from './kbn_ecs_data_quality_dashboard.devdocs.json';
diff --git a/api_docs/kbn_elastic_agent_utils.mdx b/api_docs/kbn_elastic_agent_utils.mdx
index 3fc85adc24d8a..f2ba7cee1b7c1 100644
--- a/api_docs/kbn_elastic_agent_utils.mdx
+++ b/api_docs/kbn_elastic_agent_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-elastic-agent-utils
title: "@kbn/elastic-agent-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/elastic-agent-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/elastic-agent-utils']
---
import kbnElasticAgentUtilsObj from './kbn_elastic_agent_utils.devdocs.json';
diff --git a/api_docs/kbn_elastic_assistant.mdx b/api_docs/kbn_elastic_assistant.mdx
index 53c31c2ba9dbc..62c23704699a9 100644
--- a/api_docs/kbn_elastic_assistant.mdx
+++ b/api_docs/kbn_elastic_assistant.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-elastic-assistant
title: "@kbn/elastic-assistant"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/elastic-assistant plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/elastic-assistant']
---
import kbnElasticAssistantObj from './kbn_elastic_assistant.devdocs.json';
diff --git a/api_docs/kbn_elastic_assistant_common.mdx b/api_docs/kbn_elastic_assistant_common.mdx
index 847708bd58b20..15da08c21b752 100644
--- a/api_docs/kbn_elastic_assistant_common.mdx
+++ b/api_docs/kbn_elastic_assistant_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-elastic-assistant-common
title: "@kbn/elastic-assistant-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/elastic-assistant-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/elastic-assistant-common']
---
import kbnElasticAssistantCommonObj from './kbn_elastic_assistant_common.devdocs.json';
diff --git a/api_docs/kbn_entities_schema.mdx b/api_docs/kbn_entities_schema.mdx
index 0c8f2ee84d167..afb4339060938 100644
--- a/api_docs/kbn_entities_schema.mdx
+++ b/api_docs/kbn_entities_schema.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-entities-schema
title: "@kbn/entities-schema"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/entities-schema plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/entities-schema']
---
import kbnEntitiesSchemaObj from './kbn_entities_schema.devdocs.json';
diff --git a/api_docs/kbn_es.mdx b/api_docs/kbn_es.mdx
index 6d917f9159372..4ee53b37bf35d 100644
--- a/api_docs/kbn_es.mdx
+++ b/api_docs/kbn_es.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-es
title: "@kbn/es"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/es plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es']
---
import kbnEsObj from './kbn_es.devdocs.json';
diff --git a/api_docs/kbn_es_archiver.mdx b/api_docs/kbn_es_archiver.mdx
index ad0be60318316..c9cf041c98512 100644
--- a/api_docs/kbn_es_archiver.mdx
+++ b/api_docs/kbn_es_archiver.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-es-archiver
title: "@kbn/es-archiver"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/es-archiver plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es-archiver']
---
import kbnEsArchiverObj from './kbn_es_archiver.devdocs.json';
diff --git a/api_docs/kbn_es_errors.mdx b/api_docs/kbn_es_errors.mdx
index d21b2f6b9cfd0..38a21e4c0735a 100644
--- a/api_docs/kbn_es_errors.mdx
+++ b/api_docs/kbn_es_errors.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-es-errors
title: "@kbn/es-errors"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/es-errors plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es-errors']
---
import kbnEsErrorsObj from './kbn_es_errors.devdocs.json';
diff --git a/api_docs/kbn_es_query.mdx b/api_docs/kbn_es_query.mdx
index 1453acf139715..2b3247e44d808 100644
--- a/api_docs/kbn_es_query.mdx
+++ b/api_docs/kbn_es_query.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-es-query
title: "@kbn/es-query"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/es-query plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es-query']
---
import kbnEsQueryObj from './kbn_es_query.devdocs.json';
diff --git a/api_docs/kbn_es_types.mdx b/api_docs/kbn_es_types.mdx
index 68cb78b74fb02..0fa03e5594981 100644
--- a/api_docs/kbn_es_types.mdx
+++ b/api_docs/kbn_es_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-es-types
title: "@kbn/es-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/es-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es-types']
---
import kbnEsTypesObj from './kbn_es_types.devdocs.json';
diff --git a/api_docs/kbn_eslint_plugin_imports.mdx b/api_docs/kbn_eslint_plugin_imports.mdx
index 74998cef3859b..1a4a9535f23d6 100644
--- a/api_docs/kbn_eslint_plugin_imports.mdx
+++ b/api_docs/kbn_eslint_plugin_imports.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-eslint-plugin-imports
title: "@kbn/eslint-plugin-imports"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/eslint-plugin-imports plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/eslint-plugin-imports']
---
import kbnEslintPluginImportsObj from './kbn_eslint_plugin_imports.devdocs.json';
diff --git a/api_docs/kbn_esql_ast.devdocs.json b/api_docs/kbn_esql_ast.devdocs.json
index cac01fac9555d..94ef986f9809c 100644
--- a/api_docs/kbn_esql_ast.devdocs.json
+++ b/api_docs/kbn_esql_ast.devdocs.json
@@ -17949,6 +17949,31 @@
"deprecated": false,
"trackAdoption": false
},
+ {
+ "parentPluginId": "@kbn/esql-ast",
+ "id": "def-common.ESQLFunction.operator",
+ "type": "CompoundType",
+ "tags": [],
+ "label": "operator",
+ "description": [
+ "\nA node representing the function or operator being called."
+ ],
+ "signature": [
+ {
+ "pluginId": "@kbn/esql-ast",
+ "scope": "common",
+ "docId": "kibKbnEsqlAstPluginApi",
+ "section": "def-common.ESQLParamLiteral",
+ "text": "ESQLParamLiteral"
+ },
+ " | ",
+ "ESQLIdentifier",
+ " | undefined"
+ ],
+ "path": "packages/kbn-esql-ast/src/types.ts",
+ "deprecated": false,
+ "trackAdoption": false
+ },
{
"parentPluginId": "@kbn/esql-ast",
"id": "def-common.ESQLFunction.args",
@@ -19533,6 +19558,8 @@
"text": "ESQLParamLiteral"
},
" | ",
+ "ESQLIdentifier",
+ " | ",
{
"pluginId": "@kbn/esql-ast",
"scope": "common",
@@ -19668,6 +19695,8 @@
"text": "ESQLLiteral"
},
" | ",
+ "ESQLIdentifier",
+ " | ",
{
"pluginId": "@kbn/esql-ast",
"scope": "common",
diff --git a/api_docs/kbn_esql_ast.mdx b/api_docs/kbn_esql_ast.mdx
index e217afeadca63..22e579cc69e36 100644
--- a/api_docs/kbn_esql_ast.mdx
+++ b/api_docs/kbn_esql_ast.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-esql-ast
title: "@kbn/esql-ast"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/esql-ast plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/esql-ast']
---
import kbnEsqlAstObj from './kbn_esql_ast.devdocs.json';
@@ -21,7 +21,7 @@ Contact [@elastic/kibana-esql](https://github.com/orgs/elastic/teams/kibana-esql
| Public API count | Any count | Items lacking comments | Missing exports |
|-------------------|-----------|------------------------|-----------------|
-| 269 | 1 | 211 | 34 |
+| 270 | 1 | 211 | 35 |
## Common
diff --git a/api_docs/kbn_esql_editor.mdx b/api_docs/kbn_esql_editor.mdx
index 8fc3814f77d2b..584e650834c11 100644
--- a/api_docs/kbn_esql_editor.mdx
+++ b/api_docs/kbn_esql_editor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-esql-editor
title: "@kbn/esql-editor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/esql-editor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/esql-editor']
---
import kbnEsqlEditorObj from './kbn_esql_editor.devdocs.json';
diff --git a/api_docs/kbn_esql_utils.mdx b/api_docs/kbn_esql_utils.mdx
index bf81d9d54430d..3c0ab467acce7 100644
--- a/api_docs/kbn_esql_utils.mdx
+++ b/api_docs/kbn_esql_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-esql-utils
title: "@kbn/esql-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/esql-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/esql-utils']
---
import kbnEsqlUtilsObj from './kbn_esql_utils.devdocs.json';
diff --git a/api_docs/kbn_esql_validation_autocomplete.devdocs.json b/api_docs/kbn_esql_validation_autocomplete.devdocs.json
index dc50bd8f122c6..693c134947b52 100644
--- a/api_docs/kbn_esql_validation_autocomplete.devdocs.json
+++ b/api_docs/kbn_esql_validation_autocomplete.devdocs.json
@@ -675,6 +675,8 @@
"text": "ESQLParamLiteral"
},
" | ",
+ "ESQLIdentifier",
+ " | ",
{
"pluginId": "@kbn/esql-ast",
"scope": "common",
@@ -797,6 +799,8 @@
"text": "ESQLParamLiteral"
},
" | ",
+ "ESQLIdentifier",
+ " | ",
{
"pluginId": "@kbn/esql-ast",
"scope": "common",
@@ -903,6 +907,8 @@
"text": "ESQLParamLiteral"
},
" | ",
+ "ESQLIdentifier",
+ " | ",
{
"pluginId": "@kbn/esql-ast",
"scope": "common",
@@ -1017,6 +1023,8 @@
"text": "ESQLParamLiteral"
},
" | ",
+ "ESQLIdentifier",
+ " | ",
{
"pluginId": "@kbn/esql-ast",
"scope": "common",
diff --git a/api_docs/kbn_esql_validation_autocomplete.mdx b/api_docs/kbn_esql_validation_autocomplete.mdx
index 6ec5c8faef0a7..ec3660daab104 100644
--- a/api_docs/kbn_esql_validation_autocomplete.mdx
+++ b/api_docs/kbn_esql_validation_autocomplete.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-esql-validation-autocomplete
title: "@kbn/esql-validation-autocomplete"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/esql-validation-autocomplete plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/esql-validation-autocomplete']
---
import kbnEsqlValidationAutocompleteObj from './kbn_esql_validation_autocomplete.devdocs.json';
diff --git a/api_docs/kbn_event_annotation_common.mdx b/api_docs/kbn_event_annotation_common.mdx
index abe1b5272e4ff..7ebbd05bc7908 100644
--- a/api_docs/kbn_event_annotation_common.mdx
+++ b/api_docs/kbn_event_annotation_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-event-annotation-common
title: "@kbn/event-annotation-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/event-annotation-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/event-annotation-common']
---
import kbnEventAnnotationCommonObj from './kbn_event_annotation_common.devdocs.json';
diff --git a/api_docs/kbn_event_annotation_components.mdx b/api_docs/kbn_event_annotation_components.mdx
index 2ca103ff927d8..061c2e18b4a65 100644
--- a/api_docs/kbn_event_annotation_components.mdx
+++ b/api_docs/kbn_event_annotation_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-event-annotation-components
title: "@kbn/event-annotation-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/event-annotation-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/event-annotation-components']
---
import kbnEventAnnotationComponentsObj from './kbn_event_annotation_components.devdocs.json';
diff --git a/api_docs/kbn_expandable_flyout.mdx b/api_docs/kbn_expandable_flyout.mdx
index 3e9da64b0f1d3..cefaf3f3c66a5 100644
--- a/api_docs/kbn_expandable_flyout.mdx
+++ b/api_docs/kbn_expandable_flyout.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-expandable-flyout
title: "@kbn/expandable-flyout"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/expandable-flyout plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/expandable-flyout']
---
import kbnExpandableFlyoutObj from './kbn_expandable_flyout.devdocs.json';
diff --git a/api_docs/kbn_field_types.mdx b/api_docs/kbn_field_types.mdx
index 52b75cc062350..ab93d15585361 100644
--- a/api_docs/kbn_field_types.mdx
+++ b/api_docs/kbn_field_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-field-types
title: "@kbn/field-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/field-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/field-types']
---
import kbnFieldTypesObj from './kbn_field_types.devdocs.json';
diff --git a/api_docs/kbn_field_utils.mdx b/api_docs/kbn_field_utils.mdx
index af4751f245439..76f2aae7b8575 100644
--- a/api_docs/kbn_field_utils.mdx
+++ b/api_docs/kbn_field_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-field-utils
title: "@kbn/field-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/field-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/field-utils']
---
import kbnFieldUtilsObj from './kbn_field_utils.devdocs.json';
diff --git a/api_docs/kbn_find_used_node_modules.mdx b/api_docs/kbn_find_used_node_modules.mdx
index a415ff63dae97..35d9e1d91a682 100644
--- a/api_docs/kbn_find_used_node_modules.mdx
+++ b/api_docs/kbn_find_used_node_modules.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-find-used-node-modules
title: "@kbn/find-used-node-modules"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/find-used-node-modules plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/find-used-node-modules']
---
import kbnFindUsedNodeModulesObj from './kbn_find_used_node_modules.devdocs.json';
diff --git a/api_docs/kbn_formatters.mdx b/api_docs/kbn_formatters.mdx
index 5b95fd4f91299..88b91c720c5a2 100644
--- a/api_docs/kbn_formatters.mdx
+++ b/api_docs/kbn_formatters.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-formatters
title: "@kbn/formatters"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/formatters plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/formatters']
---
import kbnFormattersObj from './kbn_formatters.devdocs.json';
diff --git a/api_docs/kbn_ftr_common_functional_services.mdx b/api_docs/kbn_ftr_common_functional_services.mdx
index 49c3c9a1ace47..6e57950109100 100644
--- a/api_docs/kbn_ftr_common_functional_services.mdx
+++ b/api_docs/kbn_ftr_common_functional_services.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ftr-common-functional-services
title: "@kbn/ftr-common-functional-services"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ftr-common-functional-services plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ftr-common-functional-services']
---
import kbnFtrCommonFunctionalServicesObj from './kbn_ftr_common_functional_services.devdocs.json';
diff --git a/api_docs/kbn_ftr_common_functional_ui_services.mdx b/api_docs/kbn_ftr_common_functional_ui_services.mdx
index 3e4589b22a58a..2219ad33b7597 100644
--- a/api_docs/kbn_ftr_common_functional_ui_services.mdx
+++ b/api_docs/kbn_ftr_common_functional_ui_services.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ftr-common-functional-ui-services
title: "@kbn/ftr-common-functional-ui-services"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ftr-common-functional-ui-services plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ftr-common-functional-ui-services']
---
import kbnFtrCommonFunctionalUiServicesObj from './kbn_ftr_common_functional_ui_services.devdocs.json';
diff --git a/api_docs/kbn_generate.mdx b/api_docs/kbn_generate.mdx
index 19ba8339166d1..bb47332c42b76 100644
--- a/api_docs/kbn_generate.mdx
+++ b/api_docs/kbn_generate.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-generate
title: "@kbn/generate"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/generate plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/generate']
---
import kbnGenerateObj from './kbn_generate.devdocs.json';
diff --git a/api_docs/kbn_generate_console_definitions.mdx b/api_docs/kbn_generate_console_definitions.mdx
index c31daae802778..22d09d4a376ec 100644
--- a/api_docs/kbn_generate_console_definitions.mdx
+++ b/api_docs/kbn_generate_console_definitions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-generate-console-definitions
title: "@kbn/generate-console-definitions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/generate-console-definitions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/generate-console-definitions']
---
import kbnGenerateConsoleDefinitionsObj from './kbn_generate_console_definitions.devdocs.json';
diff --git a/api_docs/kbn_generate_csv.mdx b/api_docs/kbn_generate_csv.mdx
index 9e6dcba376054..5c0f2927e1a1c 100644
--- a/api_docs/kbn_generate_csv.mdx
+++ b/api_docs/kbn_generate_csv.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-generate-csv
title: "@kbn/generate-csv"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/generate-csv plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/generate-csv']
---
import kbnGenerateCsvObj from './kbn_generate_csv.devdocs.json';
diff --git a/api_docs/kbn_grid_layout.mdx b/api_docs/kbn_grid_layout.mdx
index c66dfa80cc7df..cf56d3bd6175f 100644
--- a/api_docs/kbn_grid_layout.mdx
+++ b/api_docs/kbn_grid_layout.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-grid-layout
title: "@kbn/grid-layout"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/grid-layout plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/grid-layout']
---
import kbnGridLayoutObj from './kbn_grid_layout.devdocs.json';
diff --git a/api_docs/kbn_grouping.mdx b/api_docs/kbn_grouping.mdx
index 14b762cd66253..ab9ea9acafd5e 100644
--- a/api_docs/kbn_grouping.mdx
+++ b/api_docs/kbn_grouping.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-grouping
title: "@kbn/grouping"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/grouping plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/grouping']
---
import kbnGroupingObj from './kbn_grouping.devdocs.json';
diff --git a/api_docs/kbn_guided_onboarding.mdx b/api_docs/kbn_guided_onboarding.mdx
index 38916f8b3703d..fd3b9a840bc26 100644
--- a/api_docs/kbn_guided_onboarding.mdx
+++ b/api_docs/kbn_guided_onboarding.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-guided-onboarding
title: "@kbn/guided-onboarding"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/guided-onboarding plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/guided-onboarding']
---
import kbnGuidedOnboardingObj from './kbn_guided_onboarding.devdocs.json';
diff --git a/api_docs/kbn_handlebars.mdx b/api_docs/kbn_handlebars.mdx
index fbf48dede44be..9a51094601049 100644
--- a/api_docs/kbn_handlebars.mdx
+++ b/api_docs/kbn_handlebars.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-handlebars
title: "@kbn/handlebars"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/handlebars plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/handlebars']
---
import kbnHandlebarsObj from './kbn_handlebars.devdocs.json';
diff --git a/api_docs/kbn_hapi_mocks.mdx b/api_docs/kbn_hapi_mocks.mdx
index 772938292e1ca..5d95637087c79 100644
--- a/api_docs/kbn_hapi_mocks.mdx
+++ b/api_docs/kbn_hapi_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-hapi-mocks
title: "@kbn/hapi-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/hapi-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/hapi-mocks']
---
import kbnHapiMocksObj from './kbn_hapi_mocks.devdocs.json';
diff --git a/api_docs/kbn_health_gateway_server.mdx b/api_docs/kbn_health_gateway_server.mdx
index 86dc37d2b1cf9..7d634783fd184 100644
--- a/api_docs/kbn_health_gateway_server.mdx
+++ b/api_docs/kbn_health_gateway_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-health-gateway-server
title: "@kbn/health-gateway-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/health-gateway-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/health-gateway-server']
---
import kbnHealthGatewayServerObj from './kbn_health_gateway_server.devdocs.json';
diff --git a/api_docs/kbn_home_sample_data_card.mdx b/api_docs/kbn_home_sample_data_card.mdx
index 1cd3c43775693..495f0ebe9a6d8 100644
--- a/api_docs/kbn_home_sample_data_card.mdx
+++ b/api_docs/kbn_home_sample_data_card.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-home-sample-data-card
title: "@kbn/home-sample-data-card"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/home-sample-data-card plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/home-sample-data-card']
---
import kbnHomeSampleDataCardObj from './kbn_home_sample_data_card.devdocs.json';
diff --git a/api_docs/kbn_home_sample_data_tab.mdx b/api_docs/kbn_home_sample_data_tab.mdx
index 255572db7420e..92fd02436cc53 100644
--- a/api_docs/kbn_home_sample_data_tab.mdx
+++ b/api_docs/kbn_home_sample_data_tab.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-home-sample-data-tab
title: "@kbn/home-sample-data-tab"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/home-sample-data-tab plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/home-sample-data-tab']
---
import kbnHomeSampleDataTabObj from './kbn_home_sample_data_tab.devdocs.json';
diff --git a/api_docs/kbn_i18n.mdx b/api_docs/kbn_i18n.mdx
index 6db0431232ece..02b44ab6c789c 100644
--- a/api_docs/kbn_i18n.mdx
+++ b/api_docs/kbn_i18n.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-i18n
title: "@kbn/i18n"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/i18n plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/i18n']
---
import kbnI18nObj from './kbn_i18n.devdocs.json';
diff --git a/api_docs/kbn_i18n_react.mdx b/api_docs/kbn_i18n_react.mdx
index c4bf7b4535b31..ce71521dfa526 100644
--- a/api_docs/kbn_i18n_react.mdx
+++ b/api_docs/kbn_i18n_react.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-i18n-react
title: "@kbn/i18n-react"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/i18n-react plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/i18n-react']
---
import kbnI18nReactObj from './kbn_i18n_react.devdocs.json';
diff --git a/api_docs/kbn_import_resolver.mdx b/api_docs/kbn_import_resolver.mdx
index 8db9297db2443..13052b9a02512 100644
--- a/api_docs/kbn_import_resolver.mdx
+++ b/api_docs/kbn_import_resolver.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-import-resolver
title: "@kbn/import-resolver"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/import-resolver plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/import-resolver']
---
import kbnImportResolverObj from './kbn_import_resolver.devdocs.json';
diff --git a/api_docs/kbn_index_management_shared_types.mdx b/api_docs/kbn_index_management_shared_types.mdx
index 55091e500f91f..b02cb8fe57f3e 100644
--- a/api_docs/kbn_index_management_shared_types.mdx
+++ b/api_docs/kbn_index_management_shared_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-index-management-shared-types
title: "@kbn/index-management-shared-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/index-management-shared-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/index-management-shared-types']
---
import kbnIndexManagementSharedTypesObj from './kbn_index_management_shared_types.devdocs.json';
diff --git a/api_docs/kbn_inference_integration_flyout.mdx b/api_docs/kbn_inference_integration_flyout.mdx
index 07f69800425aa..b839f360785a0 100644
--- a/api_docs/kbn_inference_integration_flyout.mdx
+++ b/api_docs/kbn_inference_integration_flyout.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-inference_integration_flyout
title: "@kbn/inference_integration_flyout"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/inference_integration_flyout plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/inference_integration_flyout']
---
import kbnInferenceIntegrationFlyoutObj from './kbn_inference_integration_flyout.devdocs.json';
diff --git a/api_docs/kbn_infra_forge.mdx b/api_docs/kbn_infra_forge.mdx
index a72e5e54a6183..fa25aca9f5b92 100644
--- a/api_docs/kbn_infra_forge.mdx
+++ b/api_docs/kbn_infra_forge.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-infra-forge
title: "@kbn/infra-forge"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/infra-forge plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/infra-forge']
---
import kbnInfraForgeObj from './kbn_infra_forge.devdocs.json';
diff --git a/api_docs/kbn_interpreter.mdx b/api_docs/kbn_interpreter.mdx
index 0e13179d2fbc9..f94cee5e9b4a2 100644
--- a/api_docs/kbn_interpreter.mdx
+++ b/api_docs/kbn_interpreter.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-interpreter
title: "@kbn/interpreter"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/interpreter plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/interpreter']
---
import kbnInterpreterObj from './kbn_interpreter.devdocs.json';
diff --git a/api_docs/kbn_investigation_shared.mdx b/api_docs/kbn_investigation_shared.mdx
index 4ba0d94904f82..2f5d75ece7669 100644
--- a/api_docs/kbn_investigation_shared.mdx
+++ b/api_docs/kbn_investigation_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-investigation-shared
title: "@kbn/investigation-shared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/investigation-shared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/investigation-shared']
---
import kbnInvestigationSharedObj from './kbn_investigation_shared.devdocs.json';
diff --git a/api_docs/kbn_io_ts_utils.mdx b/api_docs/kbn_io_ts_utils.mdx
index 654cfeea56df0..ba55a2e8c9833 100644
--- a/api_docs/kbn_io_ts_utils.mdx
+++ b/api_docs/kbn_io_ts_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-io-ts-utils
title: "@kbn/io-ts-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/io-ts-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/io-ts-utils']
---
import kbnIoTsUtilsObj from './kbn_io_ts_utils.devdocs.json';
diff --git a/api_docs/kbn_ipynb.mdx b/api_docs/kbn_ipynb.mdx
index 6eae91fda5946..7528c44fc0b32 100644
--- a/api_docs/kbn_ipynb.mdx
+++ b/api_docs/kbn_ipynb.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ipynb
title: "@kbn/ipynb"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ipynb plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ipynb']
---
import kbnIpynbObj from './kbn_ipynb.devdocs.json';
diff --git a/api_docs/kbn_item_buffer.mdx b/api_docs/kbn_item_buffer.mdx
index 27d1b8fb914cd..126fdda674f82 100644
--- a/api_docs/kbn_item_buffer.mdx
+++ b/api_docs/kbn_item_buffer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-item-buffer
title: "@kbn/item-buffer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/item-buffer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/item-buffer']
---
import kbnItemBufferObj from './kbn_item_buffer.devdocs.json';
diff --git a/api_docs/kbn_jest_serializers.mdx b/api_docs/kbn_jest_serializers.mdx
index e4f23ef80862e..6bf431ee1b359 100644
--- a/api_docs/kbn_jest_serializers.mdx
+++ b/api_docs/kbn_jest_serializers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-jest-serializers
title: "@kbn/jest-serializers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/jest-serializers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/jest-serializers']
---
import kbnJestSerializersObj from './kbn_jest_serializers.devdocs.json';
diff --git a/api_docs/kbn_journeys.mdx b/api_docs/kbn_journeys.mdx
index 712d2890936d5..9e7e2face3c1a 100644
--- a/api_docs/kbn_journeys.mdx
+++ b/api_docs/kbn_journeys.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-journeys
title: "@kbn/journeys"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/journeys plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/journeys']
---
import kbnJourneysObj from './kbn_journeys.devdocs.json';
diff --git a/api_docs/kbn_json_ast.mdx b/api_docs/kbn_json_ast.mdx
index 250808cf3b15c..6f3bc7e5e5459 100644
--- a/api_docs/kbn_json_ast.mdx
+++ b/api_docs/kbn_json_ast.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-json-ast
title: "@kbn/json-ast"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/json-ast plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/json-ast']
---
import kbnJsonAstObj from './kbn_json_ast.devdocs.json';
diff --git a/api_docs/kbn_json_schemas.mdx b/api_docs/kbn_json_schemas.mdx
index d9751df8b890e..7b680e22999eb 100644
--- a/api_docs/kbn_json_schemas.mdx
+++ b/api_docs/kbn_json_schemas.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-json-schemas
title: "@kbn/json-schemas"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/json-schemas plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/json-schemas']
---
import kbnJsonSchemasObj from './kbn_json_schemas.devdocs.json';
diff --git a/api_docs/kbn_kibana_manifest_schema.mdx b/api_docs/kbn_kibana_manifest_schema.mdx
index 018f822bd8dec..6c8cb0488dee6 100644
--- a/api_docs/kbn_kibana_manifest_schema.mdx
+++ b/api_docs/kbn_kibana_manifest_schema.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-kibana-manifest-schema
title: "@kbn/kibana-manifest-schema"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/kibana-manifest-schema plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/kibana-manifest-schema']
---
import kbnKibanaManifestSchemaObj from './kbn_kibana_manifest_schema.devdocs.json';
diff --git a/api_docs/kbn_language_documentation.mdx b/api_docs/kbn_language_documentation.mdx
index 503766b940596..36a7a31bda78e 100644
--- a/api_docs/kbn_language_documentation.mdx
+++ b/api_docs/kbn_language_documentation.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-language-documentation
title: "@kbn/language-documentation"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/language-documentation plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/language-documentation']
---
import kbnLanguageDocumentationObj from './kbn_language_documentation.devdocs.json';
diff --git a/api_docs/kbn_lens_embeddable_utils.mdx b/api_docs/kbn_lens_embeddable_utils.mdx
index 78be1584019cf..72b4ad0c32564 100644
--- a/api_docs/kbn_lens_embeddable_utils.mdx
+++ b/api_docs/kbn_lens_embeddable_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-lens-embeddable-utils
title: "@kbn/lens-embeddable-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/lens-embeddable-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/lens-embeddable-utils']
---
import kbnLensEmbeddableUtilsObj from './kbn_lens_embeddable_utils.devdocs.json';
diff --git a/api_docs/kbn_lens_formula_docs.mdx b/api_docs/kbn_lens_formula_docs.mdx
index ced29d46c71ba..1c7ca2be3adb2 100644
--- a/api_docs/kbn_lens_formula_docs.mdx
+++ b/api_docs/kbn_lens_formula_docs.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-lens-formula-docs
title: "@kbn/lens-formula-docs"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/lens-formula-docs plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/lens-formula-docs']
---
import kbnLensFormulaDocsObj from './kbn_lens_formula_docs.devdocs.json';
diff --git a/api_docs/kbn_logging.mdx b/api_docs/kbn_logging.mdx
index 96b9b7fac145c..b085cd3d3942b 100644
--- a/api_docs/kbn_logging.mdx
+++ b/api_docs/kbn_logging.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-logging
title: "@kbn/logging"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/logging plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/logging']
---
import kbnLoggingObj from './kbn_logging.devdocs.json';
diff --git a/api_docs/kbn_logging_mocks.mdx b/api_docs/kbn_logging_mocks.mdx
index db192149bc5d3..9f5b42bf380e3 100644
--- a/api_docs/kbn_logging_mocks.mdx
+++ b/api_docs/kbn_logging_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-logging-mocks
title: "@kbn/logging-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/logging-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/logging-mocks']
---
import kbnLoggingMocksObj from './kbn_logging_mocks.devdocs.json';
diff --git a/api_docs/kbn_managed_content_badge.mdx b/api_docs/kbn_managed_content_badge.mdx
index cce49201c15bc..d1cf37e1ffa3b 100644
--- a/api_docs/kbn_managed_content_badge.mdx
+++ b/api_docs/kbn_managed_content_badge.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-managed-content-badge
title: "@kbn/managed-content-badge"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/managed-content-badge plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/managed-content-badge']
---
import kbnManagedContentBadgeObj from './kbn_managed_content_badge.devdocs.json';
diff --git a/api_docs/kbn_managed_vscode_config.mdx b/api_docs/kbn_managed_vscode_config.mdx
index dc269a1d8e1e0..2ff99e7fbe188 100644
--- a/api_docs/kbn_managed_vscode_config.mdx
+++ b/api_docs/kbn_managed_vscode_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-managed-vscode-config
title: "@kbn/managed-vscode-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/managed-vscode-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/managed-vscode-config']
---
import kbnManagedVscodeConfigObj from './kbn_managed_vscode_config.devdocs.json';
diff --git a/api_docs/kbn_management_cards_navigation.mdx b/api_docs/kbn_management_cards_navigation.mdx
index 36f538afe5c79..66e58b81926d7 100644
--- a/api_docs/kbn_management_cards_navigation.mdx
+++ b/api_docs/kbn_management_cards_navigation.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-cards-navigation
title: "@kbn/management-cards-navigation"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-cards-navigation plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-cards-navigation']
---
import kbnManagementCardsNavigationObj from './kbn_management_cards_navigation.devdocs.json';
diff --git a/api_docs/kbn_management_settings_application.mdx b/api_docs/kbn_management_settings_application.mdx
index c6c344b8e8bd7..a05abbb712608 100644
--- a/api_docs/kbn_management_settings_application.mdx
+++ b/api_docs/kbn_management_settings_application.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-application
title: "@kbn/management-settings-application"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-application plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-application']
---
import kbnManagementSettingsApplicationObj from './kbn_management_settings_application.devdocs.json';
diff --git a/api_docs/kbn_management_settings_components_field_category.mdx b/api_docs/kbn_management_settings_components_field_category.mdx
index e3c62c4a5199a..993c8c6f663d5 100644
--- a/api_docs/kbn_management_settings_components_field_category.mdx
+++ b/api_docs/kbn_management_settings_components_field_category.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-components-field-category
title: "@kbn/management-settings-components-field-category"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-components-field-category plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-components-field-category']
---
import kbnManagementSettingsComponentsFieldCategoryObj from './kbn_management_settings_components_field_category.devdocs.json';
diff --git a/api_docs/kbn_management_settings_components_field_input.mdx b/api_docs/kbn_management_settings_components_field_input.mdx
index fac5bc5c097d8..321d9f7a28684 100644
--- a/api_docs/kbn_management_settings_components_field_input.mdx
+++ b/api_docs/kbn_management_settings_components_field_input.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-components-field-input
title: "@kbn/management-settings-components-field-input"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-components-field-input plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-components-field-input']
---
import kbnManagementSettingsComponentsFieldInputObj from './kbn_management_settings_components_field_input.devdocs.json';
diff --git a/api_docs/kbn_management_settings_components_field_row.mdx b/api_docs/kbn_management_settings_components_field_row.mdx
index 905733c7edb11..d123c98e8f2e6 100644
--- a/api_docs/kbn_management_settings_components_field_row.mdx
+++ b/api_docs/kbn_management_settings_components_field_row.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-components-field-row
title: "@kbn/management-settings-components-field-row"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-components-field-row plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-components-field-row']
---
import kbnManagementSettingsComponentsFieldRowObj from './kbn_management_settings_components_field_row.devdocs.json';
diff --git a/api_docs/kbn_management_settings_components_form.mdx b/api_docs/kbn_management_settings_components_form.mdx
index b491fd30866f7..9c09f6758f1c5 100644
--- a/api_docs/kbn_management_settings_components_form.mdx
+++ b/api_docs/kbn_management_settings_components_form.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-components-form
title: "@kbn/management-settings-components-form"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-components-form plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-components-form']
---
import kbnManagementSettingsComponentsFormObj from './kbn_management_settings_components_form.devdocs.json';
diff --git a/api_docs/kbn_management_settings_field_definition.mdx b/api_docs/kbn_management_settings_field_definition.mdx
index afd5a582d254a..b7a4c1c242868 100644
--- a/api_docs/kbn_management_settings_field_definition.mdx
+++ b/api_docs/kbn_management_settings_field_definition.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-field-definition
title: "@kbn/management-settings-field-definition"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-field-definition plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-field-definition']
---
import kbnManagementSettingsFieldDefinitionObj from './kbn_management_settings_field_definition.devdocs.json';
diff --git a/api_docs/kbn_management_settings_ids.mdx b/api_docs/kbn_management_settings_ids.mdx
index a26f70570a01b..5b37ee9e959fc 100644
--- a/api_docs/kbn_management_settings_ids.mdx
+++ b/api_docs/kbn_management_settings_ids.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-ids
title: "@kbn/management-settings-ids"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-ids plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-ids']
---
import kbnManagementSettingsIdsObj from './kbn_management_settings_ids.devdocs.json';
diff --git a/api_docs/kbn_management_settings_section_registry.mdx b/api_docs/kbn_management_settings_section_registry.mdx
index 5dc6fd1fd59ff..44a1164bfad14 100644
--- a/api_docs/kbn_management_settings_section_registry.mdx
+++ b/api_docs/kbn_management_settings_section_registry.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-section-registry
title: "@kbn/management-settings-section-registry"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-section-registry plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-section-registry']
---
import kbnManagementSettingsSectionRegistryObj from './kbn_management_settings_section_registry.devdocs.json';
diff --git a/api_docs/kbn_management_settings_types.mdx b/api_docs/kbn_management_settings_types.mdx
index 5105f9d94c082..ff08a4d685da8 100644
--- a/api_docs/kbn_management_settings_types.mdx
+++ b/api_docs/kbn_management_settings_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-types
title: "@kbn/management-settings-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-types']
---
import kbnManagementSettingsTypesObj from './kbn_management_settings_types.devdocs.json';
diff --git a/api_docs/kbn_management_settings_utilities.mdx b/api_docs/kbn_management_settings_utilities.mdx
index b64f8319aba2c..72feb8ced8999 100644
--- a/api_docs/kbn_management_settings_utilities.mdx
+++ b/api_docs/kbn_management_settings_utilities.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-settings-utilities
title: "@kbn/management-settings-utilities"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-settings-utilities plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-settings-utilities']
---
import kbnManagementSettingsUtilitiesObj from './kbn_management_settings_utilities.devdocs.json';
diff --git a/api_docs/kbn_management_storybook_config.mdx b/api_docs/kbn_management_storybook_config.mdx
index d621ffe167e1c..a3690d43d76eb 100644
--- a/api_docs/kbn_management_storybook_config.mdx
+++ b/api_docs/kbn_management_storybook_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-management-storybook-config
title: "@kbn/management-storybook-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/management-storybook-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/management-storybook-config']
---
import kbnManagementStorybookConfigObj from './kbn_management_storybook_config.devdocs.json';
diff --git a/api_docs/kbn_manifest.mdx b/api_docs/kbn_manifest.mdx
index a9b728a4660cf..894bbbe1a2a0d 100644
--- a/api_docs/kbn_manifest.mdx
+++ b/api_docs/kbn_manifest.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-manifest
title: "@kbn/manifest"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/manifest plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/manifest']
---
import kbnManifestObj from './kbn_manifest.devdocs.json';
diff --git a/api_docs/kbn_mapbox_gl.mdx b/api_docs/kbn_mapbox_gl.mdx
index 00c8f73628dad..48dba15929695 100644
--- a/api_docs/kbn_mapbox_gl.mdx
+++ b/api_docs/kbn_mapbox_gl.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-mapbox-gl
title: "@kbn/mapbox-gl"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/mapbox-gl plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/mapbox-gl']
---
import kbnMapboxGlObj from './kbn_mapbox_gl.devdocs.json';
diff --git a/api_docs/kbn_maps_vector_tile_utils.mdx b/api_docs/kbn_maps_vector_tile_utils.mdx
index 94b8cfb0485c7..6073fb1940e94 100644
--- a/api_docs/kbn_maps_vector_tile_utils.mdx
+++ b/api_docs/kbn_maps_vector_tile_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-maps-vector-tile-utils
title: "@kbn/maps-vector-tile-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/maps-vector-tile-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/maps-vector-tile-utils']
---
import kbnMapsVectorTileUtilsObj from './kbn_maps_vector_tile_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_agg_utils.mdx b/api_docs/kbn_ml_agg_utils.mdx
index 785bac6fa0956..0618e910d7854 100644
--- a/api_docs/kbn_ml_agg_utils.mdx
+++ b/api_docs/kbn_ml_agg_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-agg-utils
title: "@kbn/ml-agg-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-agg-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-agg-utils']
---
import kbnMlAggUtilsObj from './kbn_ml_agg_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_anomaly_utils.mdx b/api_docs/kbn_ml_anomaly_utils.mdx
index c51533599d54f..df9cc8d4aeee2 100644
--- a/api_docs/kbn_ml_anomaly_utils.mdx
+++ b/api_docs/kbn_ml_anomaly_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-anomaly-utils
title: "@kbn/ml-anomaly-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-anomaly-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-anomaly-utils']
---
import kbnMlAnomalyUtilsObj from './kbn_ml_anomaly_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_cancellable_search.mdx b/api_docs/kbn_ml_cancellable_search.mdx
index 279adf6f33818..8c72b28bcb81c 100644
--- a/api_docs/kbn_ml_cancellable_search.mdx
+++ b/api_docs/kbn_ml_cancellable_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-cancellable-search
title: "@kbn/ml-cancellable-search"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-cancellable-search plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-cancellable-search']
---
import kbnMlCancellableSearchObj from './kbn_ml_cancellable_search.devdocs.json';
diff --git a/api_docs/kbn_ml_category_validator.mdx b/api_docs/kbn_ml_category_validator.mdx
index 5416737fa85f7..bfb05eb817a0c 100644
--- a/api_docs/kbn_ml_category_validator.mdx
+++ b/api_docs/kbn_ml_category_validator.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-category-validator
title: "@kbn/ml-category-validator"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-category-validator plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-category-validator']
---
import kbnMlCategoryValidatorObj from './kbn_ml_category_validator.devdocs.json';
diff --git a/api_docs/kbn_ml_chi2test.mdx b/api_docs/kbn_ml_chi2test.mdx
index 01411aaccf8a2..a048e34522a88 100644
--- a/api_docs/kbn_ml_chi2test.mdx
+++ b/api_docs/kbn_ml_chi2test.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-chi2test
title: "@kbn/ml-chi2test"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-chi2test plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-chi2test']
---
import kbnMlChi2testObj from './kbn_ml_chi2test.devdocs.json';
diff --git a/api_docs/kbn_ml_data_frame_analytics_utils.mdx b/api_docs/kbn_ml_data_frame_analytics_utils.mdx
index b6fce00e5a246..fe97a213a8aa2 100644
--- a/api_docs/kbn_ml_data_frame_analytics_utils.mdx
+++ b/api_docs/kbn_ml_data_frame_analytics_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-data-frame-analytics-utils
title: "@kbn/ml-data-frame-analytics-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-data-frame-analytics-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-data-frame-analytics-utils']
---
import kbnMlDataFrameAnalyticsUtilsObj from './kbn_ml_data_frame_analytics_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_data_grid.mdx b/api_docs/kbn_ml_data_grid.mdx
index b3fcf1bc2670f..9274edcd354b6 100644
--- a/api_docs/kbn_ml_data_grid.mdx
+++ b/api_docs/kbn_ml_data_grid.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-data-grid
title: "@kbn/ml-data-grid"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-data-grid plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-data-grid']
---
import kbnMlDataGridObj from './kbn_ml_data_grid.devdocs.json';
diff --git a/api_docs/kbn_ml_date_picker.mdx b/api_docs/kbn_ml_date_picker.mdx
index 7732b07c75376..84975f5f168a4 100644
--- a/api_docs/kbn_ml_date_picker.mdx
+++ b/api_docs/kbn_ml_date_picker.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-date-picker
title: "@kbn/ml-date-picker"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-date-picker plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-date-picker']
---
import kbnMlDatePickerObj from './kbn_ml_date_picker.devdocs.json';
diff --git a/api_docs/kbn_ml_date_utils.mdx b/api_docs/kbn_ml_date_utils.mdx
index 7646e6c1522fd..edce31ff877c0 100644
--- a/api_docs/kbn_ml_date_utils.mdx
+++ b/api_docs/kbn_ml_date_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-date-utils
title: "@kbn/ml-date-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-date-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-date-utils']
---
import kbnMlDateUtilsObj from './kbn_ml_date_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_error_utils.mdx b/api_docs/kbn_ml_error_utils.mdx
index 0788bc17e0c88..478be1861d335 100644
--- a/api_docs/kbn_ml_error_utils.mdx
+++ b/api_docs/kbn_ml_error_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-error-utils
title: "@kbn/ml-error-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-error-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-error-utils']
---
import kbnMlErrorUtilsObj from './kbn_ml_error_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_field_stats_flyout.mdx b/api_docs/kbn_ml_field_stats_flyout.mdx
index 41270ec0c65fc..16486df8fd82f 100644
--- a/api_docs/kbn_ml_field_stats_flyout.mdx
+++ b/api_docs/kbn_ml_field_stats_flyout.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-field-stats-flyout
title: "@kbn/ml-field-stats-flyout"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-field-stats-flyout plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-field-stats-flyout']
---
import kbnMlFieldStatsFlyoutObj from './kbn_ml_field_stats_flyout.devdocs.json';
diff --git a/api_docs/kbn_ml_in_memory_table.mdx b/api_docs/kbn_ml_in_memory_table.mdx
index 92f3cbc25ea32..f1458af586f6b 100644
--- a/api_docs/kbn_ml_in_memory_table.mdx
+++ b/api_docs/kbn_ml_in_memory_table.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-in-memory-table
title: "@kbn/ml-in-memory-table"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-in-memory-table plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-in-memory-table']
---
import kbnMlInMemoryTableObj from './kbn_ml_in_memory_table.devdocs.json';
diff --git a/api_docs/kbn_ml_is_defined.mdx b/api_docs/kbn_ml_is_defined.mdx
index 75ff932b90470..6f667a8e50bc9 100644
--- a/api_docs/kbn_ml_is_defined.mdx
+++ b/api_docs/kbn_ml_is_defined.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-is-defined
title: "@kbn/ml-is-defined"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-is-defined plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-is-defined']
---
import kbnMlIsDefinedObj from './kbn_ml_is_defined.devdocs.json';
diff --git a/api_docs/kbn_ml_is_populated_object.mdx b/api_docs/kbn_ml_is_populated_object.mdx
index c489ed7848eda..d2ce52623980a 100644
--- a/api_docs/kbn_ml_is_populated_object.mdx
+++ b/api_docs/kbn_ml_is_populated_object.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-is-populated-object
title: "@kbn/ml-is-populated-object"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-is-populated-object plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-is-populated-object']
---
import kbnMlIsPopulatedObjectObj from './kbn_ml_is_populated_object.devdocs.json';
diff --git a/api_docs/kbn_ml_kibana_theme.mdx b/api_docs/kbn_ml_kibana_theme.mdx
index 505b426b69203..b5076a9d3effa 100644
--- a/api_docs/kbn_ml_kibana_theme.mdx
+++ b/api_docs/kbn_ml_kibana_theme.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-kibana-theme
title: "@kbn/ml-kibana-theme"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-kibana-theme plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-kibana-theme']
---
import kbnMlKibanaThemeObj from './kbn_ml_kibana_theme.devdocs.json';
diff --git a/api_docs/kbn_ml_local_storage.mdx b/api_docs/kbn_ml_local_storage.mdx
index e4797b7f0a2e5..761543e00490e 100644
--- a/api_docs/kbn_ml_local_storage.mdx
+++ b/api_docs/kbn_ml_local_storage.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-local-storage
title: "@kbn/ml-local-storage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-local-storage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-local-storage']
---
import kbnMlLocalStorageObj from './kbn_ml_local_storage.devdocs.json';
diff --git a/api_docs/kbn_ml_nested_property.mdx b/api_docs/kbn_ml_nested_property.mdx
index d4e3cc1109472..b815853d09822 100644
--- a/api_docs/kbn_ml_nested_property.mdx
+++ b/api_docs/kbn_ml_nested_property.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-nested-property
title: "@kbn/ml-nested-property"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-nested-property plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-nested-property']
---
import kbnMlNestedPropertyObj from './kbn_ml_nested_property.devdocs.json';
diff --git a/api_docs/kbn_ml_number_utils.mdx b/api_docs/kbn_ml_number_utils.mdx
index 0c5132745dc50..6d8a3984ddc05 100644
--- a/api_docs/kbn_ml_number_utils.mdx
+++ b/api_docs/kbn_ml_number_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-number-utils
title: "@kbn/ml-number-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-number-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-number-utils']
---
import kbnMlNumberUtilsObj from './kbn_ml_number_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_parse_interval.mdx b/api_docs/kbn_ml_parse_interval.mdx
index 4fd8a4bfd07f1..5c8682910e5a5 100644
--- a/api_docs/kbn_ml_parse_interval.mdx
+++ b/api_docs/kbn_ml_parse_interval.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-parse-interval
title: "@kbn/ml-parse-interval"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-parse-interval plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-parse-interval']
---
import kbnMlParseIntervalObj from './kbn_ml_parse_interval.devdocs.json';
diff --git a/api_docs/kbn_ml_query_utils.mdx b/api_docs/kbn_ml_query_utils.mdx
index bd5a5646525ca..6c670234b48cf 100644
--- a/api_docs/kbn_ml_query_utils.mdx
+++ b/api_docs/kbn_ml_query_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-query-utils
title: "@kbn/ml-query-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-query-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-query-utils']
---
import kbnMlQueryUtilsObj from './kbn_ml_query_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_random_sampler_utils.mdx b/api_docs/kbn_ml_random_sampler_utils.mdx
index ba459e49cf7d8..46f69b352051f 100644
--- a/api_docs/kbn_ml_random_sampler_utils.mdx
+++ b/api_docs/kbn_ml_random_sampler_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-random-sampler-utils
title: "@kbn/ml-random-sampler-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-random-sampler-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-random-sampler-utils']
---
import kbnMlRandomSamplerUtilsObj from './kbn_ml_random_sampler_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_route_utils.mdx b/api_docs/kbn_ml_route_utils.mdx
index 4c14f01570f40..a3406b68d70fb 100644
--- a/api_docs/kbn_ml_route_utils.mdx
+++ b/api_docs/kbn_ml_route_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-route-utils
title: "@kbn/ml-route-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-route-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-route-utils']
---
import kbnMlRouteUtilsObj from './kbn_ml_route_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_runtime_field_utils.mdx b/api_docs/kbn_ml_runtime_field_utils.mdx
index 7d66abe607dcb..c6d46329bc94f 100644
--- a/api_docs/kbn_ml_runtime_field_utils.mdx
+++ b/api_docs/kbn_ml_runtime_field_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-runtime-field-utils
title: "@kbn/ml-runtime-field-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-runtime-field-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-runtime-field-utils']
---
import kbnMlRuntimeFieldUtilsObj from './kbn_ml_runtime_field_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_string_hash.mdx b/api_docs/kbn_ml_string_hash.mdx
index b8822bc6f6c5f..cac3ea2f80482 100644
--- a/api_docs/kbn_ml_string_hash.mdx
+++ b/api_docs/kbn_ml_string_hash.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-string-hash
title: "@kbn/ml-string-hash"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-string-hash plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-string-hash']
---
import kbnMlStringHashObj from './kbn_ml_string_hash.devdocs.json';
diff --git a/api_docs/kbn_ml_time_buckets.mdx b/api_docs/kbn_ml_time_buckets.mdx
index 23c9ac76cc187..711832559b365 100644
--- a/api_docs/kbn_ml_time_buckets.mdx
+++ b/api_docs/kbn_ml_time_buckets.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-time-buckets
title: "@kbn/ml-time-buckets"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-time-buckets plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-time-buckets']
---
import kbnMlTimeBucketsObj from './kbn_ml_time_buckets.devdocs.json';
diff --git a/api_docs/kbn_ml_trained_models_utils.mdx b/api_docs/kbn_ml_trained_models_utils.mdx
index e31420009dff9..2ab3b3960dec3 100644
--- a/api_docs/kbn_ml_trained_models_utils.mdx
+++ b/api_docs/kbn_ml_trained_models_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-trained-models-utils
title: "@kbn/ml-trained-models-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-trained-models-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-trained-models-utils']
---
import kbnMlTrainedModelsUtilsObj from './kbn_ml_trained_models_utils.devdocs.json';
diff --git a/api_docs/kbn_ml_ui_actions.mdx b/api_docs/kbn_ml_ui_actions.mdx
index e5299062d85a3..e04b931181df1 100644
--- a/api_docs/kbn_ml_ui_actions.mdx
+++ b/api_docs/kbn_ml_ui_actions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-ui-actions
title: "@kbn/ml-ui-actions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-ui-actions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-ui-actions']
---
import kbnMlUiActionsObj from './kbn_ml_ui_actions.devdocs.json';
diff --git a/api_docs/kbn_ml_url_state.mdx b/api_docs/kbn_ml_url_state.mdx
index f4f5b7f751214..1954742fbf6a7 100644
--- a/api_docs/kbn_ml_url_state.mdx
+++ b/api_docs/kbn_ml_url_state.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-url-state
title: "@kbn/ml-url-state"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-url-state plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-url-state']
---
import kbnMlUrlStateObj from './kbn_ml_url_state.devdocs.json';
diff --git a/api_docs/kbn_ml_validators.mdx b/api_docs/kbn_ml_validators.mdx
index 56223b89afada..f54e1217ff7e7 100644
--- a/api_docs/kbn_ml_validators.mdx
+++ b/api_docs/kbn_ml_validators.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ml-validators
title: "@kbn/ml-validators"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ml-validators plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ml-validators']
---
import kbnMlValidatorsObj from './kbn_ml_validators.devdocs.json';
diff --git a/api_docs/kbn_mock_idp_utils.mdx b/api_docs/kbn_mock_idp_utils.mdx
index 9e0cae501f63d..5e07ee7896f78 100644
--- a/api_docs/kbn_mock_idp_utils.mdx
+++ b/api_docs/kbn_mock_idp_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-mock-idp-utils
title: "@kbn/mock-idp-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/mock-idp-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/mock-idp-utils']
---
import kbnMockIdpUtilsObj from './kbn_mock_idp_utils.devdocs.json';
diff --git a/api_docs/kbn_monaco.mdx b/api_docs/kbn_monaco.mdx
index ad0de0ef05521..3f5038fa197e4 100644
--- a/api_docs/kbn_monaco.mdx
+++ b/api_docs/kbn_monaco.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-monaco
title: "@kbn/monaco"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/monaco plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/monaco']
---
import kbnMonacoObj from './kbn_monaco.devdocs.json';
diff --git a/api_docs/kbn_object_versioning.mdx b/api_docs/kbn_object_versioning.mdx
index 30001990cef70..97a226db0d6ea 100644
--- a/api_docs/kbn_object_versioning.mdx
+++ b/api_docs/kbn_object_versioning.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-object-versioning
title: "@kbn/object-versioning"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/object-versioning plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/object-versioning']
---
import kbnObjectVersioningObj from './kbn_object_versioning.devdocs.json';
diff --git a/api_docs/kbn_object_versioning_utils.mdx b/api_docs/kbn_object_versioning_utils.mdx
index 4abd459a0139f..3585efc6ddd7f 100644
--- a/api_docs/kbn_object_versioning_utils.mdx
+++ b/api_docs/kbn_object_versioning_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-object-versioning-utils
title: "@kbn/object-versioning-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/object-versioning-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/object-versioning-utils']
---
import kbnObjectVersioningUtilsObj from './kbn_object_versioning_utils.devdocs.json';
diff --git a/api_docs/kbn_observability_alert_details.mdx b/api_docs/kbn_observability_alert_details.mdx
index 6e0c9d360ebb0..90b09f178ab48 100644
--- a/api_docs/kbn_observability_alert_details.mdx
+++ b/api_docs/kbn_observability_alert_details.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-observability-alert-details
title: "@kbn/observability-alert-details"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/observability-alert-details plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/observability-alert-details']
---
import kbnObservabilityAlertDetailsObj from './kbn_observability_alert_details.devdocs.json';
diff --git a/api_docs/kbn_observability_alerting_rule_utils.mdx b/api_docs/kbn_observability_alerting_rule_utils.mdx
index 7b82e5a13cc5d..40825dbebdc1f 100644
--- a/api_docs/kbn_observability_alerting_rule_utils.mdx
+++ b/api_docs/kbn_observability_alerting_rule_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-observability-alerting-rule-utils
title: "@kbn/observability-alerting-rule-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/observability-alerting-rule-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/observability-alerting-rule-utils']
---
import kbnObservabilityAlertingRuleUtilsObj from './kbn_observability_alerting_rule_utils.devdocs.json';
diff --git a/api_docs/kbn_observability_alerting_test_data.mdx b/api_docs/kbn_observability_alerting_test_data.mdx
index 4a8e828a3b3c2..82294bcd86e8b 100644
--- a/api_docs/kbn_observability_alerting_test_data.mdx
+++ b/api_docs/kbn_observability_alerting_test_data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-observability-alerting-test-data
title: "@kbn/observability-alerting-test-data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/observability-alerting-test-data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/observability-alerting-test-data']
---
import kbnObservabilityAlertingTestDataObj from './kbn_observability_alerting_test_data.devdocs.json';
diff --git a/api_docs/kbn_observability_get_padded_alert_time_range_util.mdx b/api_docs/kbn_observability_get_padded_alert_time_range_util.mdx
index 49bda6abf4f78..531529dd6be3d 100644
--- a/api_docs/kbn_observability_get_padded_alert_time_range_util.mdx
+++ b/api_docs/kbn_observability_get_padded_alert_time_range_util.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-observability-get-padded-alert-time-range-util
title: "@kbn/observability-get-padded-alert-time-range-util"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/observability-get-padded-alert-time-range-util plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/observability-get-padded-alert-time-range-util']
---
import kbnObservabilityGetPaddedAlertTimeRangeUtilObj from './kbn_observability_get_padded_alert_time_range_util.devdocs.json';
diff --git a/api_docs/kbn_observability_logs_overview.mdx b/api_docs/kbn_observability_logs_overview.mdx
index 826c8662e489d..c28edaeb707ee 100644
--- a/api_docs/kbn_observability_logs_overview.mdx
+++ b/api_docs/kbn_observability_logs_overview.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-observability-logs-overview
title: "@kbn/observability-logs-overview"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/observability-logs-overview plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/observability-logs-overview']
---
import kbnObservabilityLogsOverviewObj from './kbn_observability_logs_overview.devdocs.json';
diff --git a/api_docs/kbn_observability_synthetics_test_data.mdx b/api_docs/kbn_observability_synthetics_test_data.mdx
index 356ed2ba7a512..ccd773d013b07 100644
--- a/api_docs/kbn_observability_synthetics_test_data.mdx
+++ b/api_docs/kbn_observability_synthetics_test_data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-observability-synthetics-test-data
title: "@kbn/observability-synthetics-test-data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/observability-synthetics-test-data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/observability-synthetics-test-data']
---
import kbnObservabilitySyntheticsTestDataObj from './kbn_observability_synthetics_test_data.devdocs.json';
diff --git a/api_docs/kbn_openapi_bundler.mdx b/api_docs/kbn_openapi_bundler.mdx
index 44251d313edaf..6d948dc92f6e3 100644
--- a/api_docs/kbn_openapi_bundler.mdx
+++ b/api_docs/kbn_openapi_bundler.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-openapi-bundler
title: "@kbn/openapi-bundler"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/openapi-bundler plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/openapi-bundler']
---
import kbnOpenapiBundlerObj from './kbn_openapi_bundler.devdocs.json';
diff --git a/api_docs/kbn_openapi_generator.mdx b/api_docs/kbn_openapi_generator.mdx
index 0252382f2f494..6131bafc8283f 100644
--- a/api_docs/kbn_openapi_generator.mdx
+++ b/api_docs/kbn_openapi_generator.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-openapi-generator
title: "@kbn/openapi-generator"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/openapi-generator plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/openapi-generator']
---
import kbnOpenapiGeneratorObj from './kbn_openapi_generator.devdocs.json';
diff --git a/api_docs/kbn_optimizer.mdx b/api_docs/kbn_optimizer.mdx
index 7a768c57f8085..e47aef25a65b8 100644
--- a/api_docs/kbn_optimizer.mdx
+++ b/api_docs/kbn_optimizer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-optimizer
title: "@kbn/optimizer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/optimizer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/optimizer']
---
import kbnOptimizerObj from './kbn_optimizer.devdocs.json';
diff --git a/api_docs/kbn_optimizer_webpack_helpers.mdx b/api_docs/kbn_optimizer_webpack_helpers.mdx
index 297f160cacc57..8d5afa2484e2b 100644
--- a/api_docs/kbn_optimizer_webpack_helpers.mdx
+++ b/api_docs/kbn_optimizer_webpack_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-optimizer-webpack-helpers
title: "@kbn/optimizer-webpack-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/optimizer-webpack-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/optimizer-webpack-helpers']
---
import kbnOptimizerWebpackHelpersObj from './kbn_optimizer_webpack_helpers.devdocs.json';
diff --git a/api_docs/kbn_osquery_io_ts_types.mdx b/api_docs/kbn_osquery_io_ts_types.mdx
index 58bfdc9804d90..e06f3265e6f8a 100644
--- a/api_docs/kbn_osquery_io_ts_types.mdx
+++ b/api_docs/kbn_osquery_io_ts_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-osquery-io-ts-types
title: "@kbn/osquery-io-ts-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/osquery-io-ts-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/osquery-io-ts-types']
---
import kbnOsqueryIoTsTypesObj from './kbn_osquery_io_ts_types.devdocs.json';
diff --git a/api_docs/kbn_panel_loader.mdx b/api_docs/kbn_panel_loader.mdx
index be5552ce3d11c..3cdde73e4c3df 100644
--- a/api_docs/kbn_panel_loader.mdx
+++ b/api_docs/kbn_panel_loader.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-panel-loader
title: "@kbn/panel-loader"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/panel-loader plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/panel-loader']
---
import kbnPanelLoaderObj from './kbn_panel_loader.devdocs.json';
diff --git a/api_docs/kbn_performance_testing_dataset_extractor.mdx b/api_docs/kbn_performance_testing_dataset_extractor.mdx
index 4e2e64298f795..c2c303725cdcb 100644
--- a/api_docs/kbn_performance_testing_dataset_extractor.mdx
+++ b/api_docs/kbn_performance_testing_dataset_extractor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-performance-testing-dataset-extractor
title: "@kbn/performance-testing-dataset-extractor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/performance-testing-dataset-extractor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/performance-testing-dataset-extractor']
---
import kbnPerformanceTestingDatasetExtractorObj from './kbn_performance_testing_dataset_extractor.devdocs.json';
diff --git a/api_docs/kbn_plugin_check.mdx b/api_docs/kbn_plugin_check.mdx
index a5cf24e656b84..16d1c33731be3 100644
--- a/api_docs/kbn_plugin_check.mdx
+++ b/api_docs/kbn_plugin_check.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-plugin-check
title: "@kbn/plugin-check"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/plugin-check plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/plugin-check']
---
import kbnPluginCheckObj from './kbn_plugin_check.devdocs.json';
diff --git a/api_docs/kbn_plugin_generator.mdx b/api_docs/kbn_plugin_generator.mdx
index 7856136819404..22e2b9471d8ab 100644
--- a/api_docs/kbn_plugin_generator.mdx
+++ b/api_docs/kbn_plugin_generator.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-plugin-generator
title: "@kbn/plugin-generator"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/plugin-generator plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/plugin-generator']
---
import kbnPluginGeneratorObj from './kbn_plugin_generator.devdocs.json';
diff --git a/api_docs/kbn_plugin_helpers.mdx b/api_docs/kbn_plugin_helpers.mdx
index a30609c739929..6bf31a6dabbf1 100644
--- a/api_docs/kbn_plugin_helpers.mdx
+++ b/api_docs/kbn_plugin_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-plugin-helpers
title: "@kbn/plugin-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/plugin-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/plugin-helpers']
---
import kbnPluginHelpersObj from './kbn_plugin_helpers.devdocs.json';
diff --git a/api_docs/kbn_presentation_containers.mdx b/api_docs/kbn_presentation_containers.mdx
index cd47aef2f7716..fb0b93d347916 100644
--- a/api_docs/kbn_presentation_containers.mdx
+++ b/api_docs/kbn_presentation_containers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-presentation-containers
title: "@kbn/presentation-containers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/presentation-containers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/presentation-containers']
---
import kbnPresentationContainersObj from './kbn_presentation_containers.devdocs.json';
diff --git a/api_docs/kbn_presentation_publishing.mdx b/api_docs/kbn_presentation_publishing.mdx
index 683014c8fabad..085f99197db80 100644
--- a/api_docs/kbn_presentation_publishing.mdx
+++ b/api_docs/kbn_presentation_publishing.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-presentation-publishing
title: "@kbn/presentation-publishing"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/presentation-publishing plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/presentation-publishing']
---
import kbnPresentationPublishingObj from './kbn_presentation_publishing.devdocs.json';
diff --git a/api_docs/kbn_product_doc_artifact_builder.mdx b/api_docs/kbn_product_doc_artifact_builder.mdx
index 87724d04758fb..c6ff65cc0bdc9 100644
--- a/api_docs/kbn_product_doc_artifact_builder.mdx
+++ b/api_docs/kbn_product_doc_artifact_builder.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-product-doc-artifact-builder
title: "@kbn/product-doc-artifact-builder"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/product-doc-artifact-builder plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/product-doc-artifact-builder']
---
import kbnProductDocArtifactBuilderObj from './kbn_product_doc_artifact_builder.devdocs.json';
diff --git a/api_docs/kbn_profiling_utils.mdx b/api_docs/kbn_profiling_utils.mdx
index adeee73fa1487..0483e6e701ffd 100644
--- a/api_docs/kbn_profiling_utils.mdx
+++ b/api_docs/kbn_profiling_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-profiling-utils
title: "@kbn/profiling-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/profiling-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/profiling-utils']
---
import kbnProfilingUtilsObj from './kbn_profiling_utils.devdocs.json';
diff --git a/api_docs/kbn_random_sampling.mdx b/api_docs/kbn_random_sampling.mdx
index 123e08a35f7aa..8c581345e99d3 100644
--- a/api_docs/kbn_random_sampling.mdx
+++ b/api_docs/kbn_random_sampling.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-random-sampling
title: "@kbn/random-sampling"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/random-sampling plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/random-sampling']
---
import kbnRandomSamplingObj from './kbn_random_sampling.devdocs.json';
diff --git a/api_docs/kbn_react_field.mdx b/api_docs/kbn_react_field.mdx
index ff0e4f91b1cae..529e9aa44c96f 100644
--- a/api_docs/kbn_react_field.mdx
+++ b/api_docs/kbn_react_field.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-field
title: "@kbn/react-field"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-field plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-field']
---
import kbnReactFieldObj from './kbn_react_field.devdocs.json';
diff --git a/api_docs/kbn_react_hooks.mdx b/api_docs/kbn_react_hooks.mdx
index ac32d5f3b99d5..a05902457fc03 100644
--- a/api_docs/kbn_react_hooks.mdx
+++ b/api_docs/kbn_react_hooks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-hooks
title: "@kbn/react-hooks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-hooks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-hooks']
---
import kbnReactHooksObj from './kbn_react_hooks.devdocs.json';
diff --git a/api_docs/kbn_react_kibana_context_common.mdx b/api_docs/kbn_react_kibana_context_common.mdx
index 63ceca85e0cb1..6797474980c88 100644
--- a/api_docs/kbn_react_kibana_context_common.mdx
+++ b/api_docs/kbn_react_kibana_context_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-kibana-context-common
title: "@kbn/react-kibana-context-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-kibana-context-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-kibana-context-common']
---
import kbnReactKibanaContextCommonObj from './kbn_react_kibana_context_common.devdocs.json';
diff --git a/api_docs/kbn_react_kibana_context_render.mdx b/api_docs/kbn_react_kibana_context_render.mdx
index 4d2930de68882..ffcad7ffcc68c 100644
--- a/api_docs/kbn_react_kibana_context_render.mdx
+++ b/api_docs/kbn_react_kibana_context_render.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-kibana-context-render
title: "@kbn/react-kibana-context-render"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-kibana-context-render plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-kibana-context-render']
---
import kbnReactKibanaContextRenderObj from './kbn_react_kibana_context_render.devdocs.json';
diff --git a/api_docs/kbn_react_kibana_context_root.mdx b/api_docs/kbn_react_kibana_context_root.mdx
index 7f1d26969d84e..d6c5c514c7986 100644
--- a/api_docs/kbn_react_kibana_context_root.mdx
+++ b/api_docs/kbn_react_kibana_context_root.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-kibana-context-root
title: "@kbn/react-kibana-context-root"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-kibana-context-root plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-kibana-context-root']
---
import kbnReactKibanaContextRootObj from './kbn_react_kibana_context_root.devdocs.json';
diff --git a/api_docs/kbn_react_kibana_context_styled.mdx b/api_docs/kbn_react_kibana_context_styled.mdx
index 7f2f8edf28d47..74ac20a794fef 100644
--- a/api_docs/kbn_react_kibana_context_styled.mdx
+++ b/api_docs/kbn_react_kibana_context_styled.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-kibana-context-styled
title: "@kbn/react-kibana-context-styled"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-kibana-context-styled plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-kibana-context-styled']
---
import kbnReactKibanaContextStyledObj from './kbn_react_kibana_context_styled.devdocs.json';
diff --git a/api_docs/kbn_react_kibana_context_theme.mdx b/api_docs/kbn_react_kibana_context_theme.mdx
index 7ba0044639649..424ec359a3305 100644
--- a/api_docs/kbn_react_kibana_context_theme.mdx
+++ b/api_docs/kbn_react_kibana_context_theme.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-kibana-context-theme
title: "@kbn/react-kibana-context-theme"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-kibana-context-theme plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-kibana-context-theme']
---
import kbnReactKibanaContextThemeObj from './kbn_react_kibana_context_theme.devdocs.json';
diff --git a/api_docs/kbn_react_kibana_mount.mdx b/api_docs/kbn_react_kibana_mount.mdx
index 5b52c7066ce5c..172bed73698bc 100644
--- a/api_docs/kbn_react_kibana_mount.mdx
+++ b/api_docs/kbn_react_kibana_mount.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-react-kibana-mount
title: "@kbn/react-kibana-mount"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/react-kibana-mount plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-kibana-mount']
---
import kbnReactKibanaMountObj from './kbn_react_kibana_mount.devdocs.json';
diff --git a/api_docs/kbn_recently_accessed.mdx b/api_docs/kbn_recently_accessed.mdx
index c95a88bafa2b3..9b886144c0613 100644
--- a/api_docs/kbn_recently_accessed.mdx
+++ b/api_docs/kbn_recently_accessed.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-recently-accessed
title: "@kbn/recently-accessed"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/recently-accessed plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/recently-accessed']
---
import kbnRecentlyAccessedObj from './kbn_recently_accessed.devdocs.json';
diff --git a/api_docs/kbn_repo_file_maps.mdx b/api_docs/kbn_repo_file_maps.mdx
index d9fb93fcb1c88..2776dd3bfc4ea 100644
--- a/api_docs/kbn_repo_file_maps.mdx
+++ b/api_docs/kbn_repo_file_maps.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-repo-file-maps
title: "@kbn/repo-file-maps"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/repo-file-maps plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/repo-file-maps']
---
import kbnRepoFileMapsObj from './kbn_repo_file_maps.devdocs.json';
diff --git a/api_docs/kbn_repo_linter.mdx b/api_docs/kbn_repo_linter.mdx
index 3431698c9836a..949ff38cc2a9c 100644
--- a/api_docs/kbn_repo_linter.mdx
+++ b/api_docs/kbn_repo_linter.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-repo-linter
title: "@kbn/repo-linter"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/repo-linter plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/repo-linter']
---
import kbnRepoLinterObj from './kbn_repo_linter.devdocs.json';
diff --git a/api_docs/kbn_repo_path.mdx b/api_docs/kbn_repo_path.mdx
index d9602328becdc..bd8d93794c148 100644
--- a/api_docs/kbn_repo_path.mdx
+++ b/api_docs/kbn_repo_path.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-repo-path
title: "@kbn/repo-path"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/repo-path plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/repo-path']
---
import kbnRepoPathObj from './kbn_repo_path.devdocs.json';
diff --git a/api_docs/kbn_repo_source_classifier.mdx b/api_docs/kbn_repo_source_classifier.mdx
index d8b2d1dc4e9b8..db91a1d12be3d 100644
--- a/api_docs/kbn_repo_source_classifier.mdx
+++ b/api_docs/kbn_repo_source_classifier.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-repo-source-classifier
title: "@kbn/repo-source-classifier"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/repo-source-classifier plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/repo-source-classifier']
---
import kbnRepoSourceClassifierObj from './kbn_repo_source_classifier.devdocs.json';
diff --git a/api_docs/kbn_reporting_common.mdx b/api_docs/kbn_reporting_common.mdx
index 871d3f14fc628..13aad08016a5f 100644
--- a/api_docs/kbn_reporting_common.mdx
+++ b/api_docs/kbn_reporting_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-common
title: "@kbn/reporting-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-common']
---
import kbnReportingCommonObj from './kbn_reporting_common.devdocs.json';
diff --git a/api_docs/kbn_reporting_csv_share_panel.mdx b/api_docs/kbn_reporting_csv_share_panel.mdx
index 7d93d6f35ca86..5a6ec3367544a 100644
--- a/api_docs/kbn_reporting_csv_share_panel.mdx
+++ b/api_docs/kbn_reporting_csv_share_panel.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-csv-share-panel
title: "@kbn/reporting-csv-share-panel"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-csv-share-panel plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-csv-share-panel']
---
import kbnReportingCsvSharePanelObj from './kbn_reporting_csv_share_panel.devdocs.json';
diff --git a/api_docs/kbn_reporting_export_types_csv.mdx b/api_docs/kbn_reporting_export_types_csv.mdx
index 21586e2384f5f..fd26d914e0cc5 100644
--- a/api_docs/kbn_reporting_export_types_csv.mdx
+++ b/api_docs/kbn_reporting_export_types_csv.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-export-types-csv
title: "@kbn/reporting-export-types-csv"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-export-types-csv plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-export-types-csv']
---
import kbnReportingExportTypesCsvObj from './kbn_reporting_export_types_csv.devdocs.json';
diff --git a/api_docs/kbn_reporting_export_types_csv_common.mdx b/api_docs/kbn_reporting_export_types_csv_common.mdx
index 21d007381e4d5..56291c360a70c 100644
--- a/api_docs/kbn_reporting_export_types_csv_common.mdx
+++ b/api_docs/kbn_reporting_export_types_csv_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-export-types-csv-common
title: "@kbn/reporting-export-types-csv-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-export-types-csv-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-export-types-csv-common']
---
import kbnReportingExportTypesCsvCommonObj from './kbn_reporting_export_types_csv_common.devdocs.json';
diff --git a/api_docs/kbn_reporting_export_types_pdf.mdx b/api_docs/kbn_reporting_export_types_pdf.mdx
index 1f79350746453..d5cf270543a5a 100644
--- a/api_docs/kbn_reporting_export_types_pdf.mdx
+++ b/api_docs/kbn_reporting_export_types_pdf.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-export-types-pdf
title: "@kbn/reporting-export-types-pdf"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-export-types-pdf plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-export-types-pdf']
---
import kbnReportingExportTypesPdfObj from './kbn_reporting_export_types_pdf.devdocs.json';
diff --git a/api_docs/kbn_reporting_export_types_pdf_common.mdx b/api_docs/kbn_reporting_export_types_pdf_common.mdx
index 51e5c22c987c9..eadd6af46ed0a 100644
--- a/api_docs/kbn_reporting_export_types_pdf_common.mdx
+++ b/api_docs/kbn_reporting_export_types_pdf_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-export-types-pdf-common
title: "@kbn/reporting-export-types-pdf-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-export-types-pdf-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-export-types-pdf-common']
---
import kbnReportingExportTypesPdfCommonObj from './kbn_reporting_export_types_pdf_common.devdocs.json';
diff --git a/api_docs/kbn_reporting_export_types_png.mdx b/api_docs/kbn_reporting_export_types_png.mdx
index 071ebd8ddea56..ec324e0ac1251 100644
--- a/api_docs/kbn_reporting_export_types_png.mdx
+++ b/api_docs/kbn_reporting_export_types_png.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-export-types-png
title: "@kbn/reporting-export-types-png"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-export-types-png plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-export-types-png']
---
import kbnReportingExportTypesPngObj from './kbn_reporting_export_types_png.devdocs.json';
diff --git a/api_docs/kbn_reporting_export_types_png_common.mdx b/api_docs/kbn_reporting_export_types_png_common.mdx
index 6d6f829f3c075..32c6c8a6e3010 100644
--- a/api_docs/kbn_reporting_export_types_png_common.mdx
+++ b/api_docs/kbn_reporting_export_types_png_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-export-types-png-common
title: "@kbn/reporting-export-types-png-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-export-types-png-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-export-types-png-common']
---
import kbnReportingExportTypesPngCommonObj from './kbn_reporting_export_types_png_common.devdocs.json';
diff --git a/api_docs/kbn_reporting_mocks_server.mdx b/api_docs/kbn_reporting_mocks_server.mdx
index 9659144c07f52..980b11fe26182 100644
--- a/api_docs/kbn_reporting_mocks_server.mdx
+++ b/api_docs/kbn_reporting_mocks_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-mocks-server
title: "@kbn/reporting-mocks-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-mocks-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-mocks-server']
---
import kbnReportingMocksServerObj from './kbn_reporting_mocks_server.devdocs.json';
diff --git a/api_docs/kbn_reporting_public.mdx b/api_docs/kbn_reporting_public.mdx
index dac3b11a54a18..18029cba3725f 100644
--- a/api_docs/kbn_reporting_public.mdx
+++ b/api_docs/kbn_reporting_public.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-public
title: "@kbn/reporting-public"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-public plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-public']
---
import kbnReportingPublicObj from './kbn_reporting_public.devdocs.json';
diff --git a/api_docs/kbn_reporting_server.mdx b/api_docs/kbn_reporting_server.mdx
index 04a8b9d1f89ff..f3ad45c695a8b 100644
--- a/api_docs/kbn_reporting_server.mdx
+++ b/api_docs/kbn_reporting_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-reporting-server
title: "@kbn/reporting-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/reporting-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/reporting-server']
---
import kbnReportingServerObj from './kbn_reporting_server.devdocs.json';
diff --git a/api_docs/kbn_resizable_layout.mdx b/api_docs/kbn_resizable_layout.mdx
index 5cf3989a16bc7..c31bc4392b78a 100644
--- a/api_docs/kbn_resizable_layout.mdx
+++ b/api_docs/kbn_resizable_layout.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-resizable-layout
title: "@kbn/resizable-layout"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/resizable-layout plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/resizable-layout']
---
import kbnResizableLayoutObj from './kbn_resizable_layout.devdocs.json';
diff --git a/api_docs/kbn_response_ops_feature_flag_service.mdx b/api_docs/kbn_response_ops_feature_flag_service.mdx
index 5866add415dec..e7d2e5a426cd9 100644
--- a/api_docs/kbn_response_ops_feature_flag_service.mdx
+++ b/api_docs/kbn_response_ops_feature_flag_service.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-response-ops-feature-flag-service
title: "@kbn/response-ops-feature-flag-service"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/response-ops-feature-flag-service plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/response-ops-feature-flag-service']
---
import kbnResponseOpsFeatureFlagServiceObj from './kbn_response_ops_feature_flag_service.devdocs.json';
diff --git a/api_docs/kbn_response_ops_rule_params.mdx b/api_docs/kbn_response_ops_rule_params.mdx
index 0333ada658fc7..feb2af634a15f 100644
--- a/api_docs/kbn_response_ops_rule_params.mdx
+++ b/api_docs/kbn_response_ops_rule_params.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-response-ops-rule-params
title: "@kbn/response-ops-rule-params"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/response-ops-rule-params plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/response-ops-rule-params']
---
import kbnResponseOpsRuleParamsObj from './kbn_response_ops_rule_params.devdocs.json';
diff --git a/api_docs/kbn_rison.mdx b/api_docs/kbn_rison.mdx
index 91713dd5fad79..816d0c143af6f 100644
--- a/api_docs/kbn_rison.mdx
+++ b/api_docs/kbn_rison.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-rison
title: "@kbn/rison"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/rison plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/rison']
---
import kbnRisonObj from './kbn_rison.devdocs.json';
diff --git a/api_docs/kbn_rollup.mdx b/api_docs/kbn_rollup.mdx
index d955d70726ccc..0289d4f21787a 100644
--- a/api_docs/kbn_rollup.mdx
+++ b/api_docs/kbn_rollup.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-rollup
title: "@kbn/rollup"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/rollup plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/rollup']
---
import kbnRollupObj from './kbn_rollup.devdocs.json';
diff --git a/api_docs/kbn_router_to_openapispec.mdx b/api_docs/kbn_router_to_openapispec.mdx
index 51f42e2bb5bbb..9e2961d6ead6b 100644
--- a/api_docs/kbn_router_to_openapispec.mdx
+++ b/api_docs/kbn_router_to_openapispec.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-router-to-openapispec
title: "@kbn/router-to-openapispec"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/router-to-openapispec plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/router-to-openapispec']
---
import kbnRouterToOpenapispecObj from './kbn_router_to_openapispec.devdocs.json';
diff --git a/api_docs/kbn_router_utils.mdx b/api_docs/kbn_router_utils.mdx
index 9cd7d37462343..6aeb25da99a64 100644
--- a/api_docs/kbn_router_utils.mdx
+++ b/api_docs/kbn_router_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-router-utils
title: "@kbn/router-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/router-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/router-utils']
---
import kbnRouterUtilsObj from './kbn_router_utils.devdocs.json';
diff --git a/api_docs/kbn_rrule.mdx b/api_docs/kbn_rrule.mdx
index 782ed50776dd9..4ef0f7307ca04 100644
--- a/api_docs/kbn_rrule.mdx
+++ b/api_docs/kbn_rrule.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-rrule
title: "@kbn/rrule"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/rrule plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/rrule']
---
import kbnRruleObj from './kbn_rrule.devdocs.json';
diff --git a/api_docs/kbn_rule_data_utils.mdx b/api_docs/kbn_rule_data_utils.mdx
index 2e39d3b64f96f..9072af5098a72 100644
--- a/api_docs/kbn_rule_data_utils.mdx
+++ b/api_docs/kbn_rule_data_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-rule-data-utils
title: "@kbn/rule-data-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/rule-data-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/rule-data-utils']
---
import kbnRuleDataUtilsObj from './kbn_rule_data_utils.devdocs.json';
diff --git a/api_docs/kbn_saved_objects_settings.mdx b/api_docs/kbn_saved_objects_settings.mdx
index 3322f5c9be03c..3635d5b831270 100644
--- a/api_docs/kbn_saved_objects_settings.mdx
+++ b/api_docs/kbn_saved_objects_settings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-saved-objects-settings
title: "@kbn/saved-objects-settings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/saved-objects-settings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/saved-objects-settings']
---
import kbnSavedObjectsSettingsObj from './kbn_saved_objects_settings.devdocs.json';
diff --git a/api_docs/kbn_screenshotting_server.mdx b/api_docs/kbn_screenshotting_server.mdx
index 589fe72b29571..523f5ee048a6f 100644
--- a/api_docs/kbn_screenshotting_server.mdx
+++ b/api_docs/kbn_screenshotting_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-screenshotting-server
title: "@kbn/screenshotting-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/screenshotting-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/screenshotting-server']
---
import kbnScreenshottingServerObj from './kbn_screenshotting_server.devdocs.json';
diff --git a/api_docs/kbn_search_api_keys_components.mdx b/api_docs/kbn_search_api_keys_components.mdx
index f382b5742a03d..e28cc7d83764d 100644
--- a/api_docs/kbn_search_api_keys_components.mdx
+++ b/api_docs/kbn_search_api_keys_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-api-keys-components
title: "@kbn/search-api-keys-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-api-keys-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-api-keys-components']
---
import kbnSearchApiKeysComponentsObj from './kbn_search_api_keys_components.devdocs.json';
diff --git a/api_docs/kbn_search_api_keys_server.mdx b/api_docs/kbn_search_api_keys_server.mdx
index b283087d253f6..6ad8fca7a460e 100644
--- a/api_docs/kbn_search_api_keys_server.mdx
+++ b/api_docs/kbn_search_api_keys_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-api-keys-server
title: "@kbn/search-api-keys-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-api-keys-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-api-keys-server']
---
import kbnSearchApiKeysServerObj from './kbn_search_api_keys_server.devdocs.json';
diff --git a/api_docs/kbn_search_api_panels.mdx b/api_docs/kbn_search_api_panels.mdx
index 1a58a695c8147..abb550e5d1711 100644
--- a/api_docs/kbn_search_api_panels.mdx
+++ b/api_docs/kbn_search_api_panels.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-api-panels
title: "@kbn/search-api-panels"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-api-panels plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-api-panels']
---
import kbnSearchApiPanelsObj from './kbn_search_api_panels.devdocs.json';
diff --git a/api_docs/kbn_search_connectors.mdx b/api_docs/kbn_search_connectors.mdx
index 10bb5a7646f8d..da7204a29cca2 100644
--- a/api_docs/kbn_search_connectors.mdx
+++ b/api_docs/kbn_search_connectors.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-connectors
title: "@kbn/search-connectors"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-connectors plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-connectors']
---
import kbnSearchConnectorsObj from './kbn_search_connectors.devdocs.json';
diff --git a/api_docs/kbn_search_errors.mdx b/api_docs/kbn_search_errors.mdx
index 63bebf74916ff..4924ee31ab124 100644
--- a/api_docs/kbn_search_errors.mdx
+++ b/api_docs/kbn_search_errors.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-errors
title: "@kbn/search-errors"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-errors plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-errors']
---
import kbnSearchErrorsObj from './kbn_search_errors.devdocs.json';
diff --git a/api_docs/kbn_search_index_documents.mdx b/api_docs/kbn_search_index_documents.mdx
index b7f851cdf861f..cb7ad770a197d 100644
--- a/api_docs/kbn_search_index_documents.mdx
+++ b/api_docs/kbn_search_index_documents.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-index-documents
title: "@kbn/search-index-documents"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-index-documents plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-index-documents']
---
import kbnSearchIndexDocumentsObj from './kbn_search_index_documents.devdocs.json';
diff --git a/api_docs/kbn_search_response_warnings.mdx b/api_docs/kbn_search_response_warnings.mdx
index 082f9ea9ebc25..c280e76cd7b13 100644
--- a/api_docs/kbn_search_response_warnings.mdx
+++ b/api_docs/kbn_search_response_warnings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-response-warnings
title: "@kbn/search-response-warnings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-response-warnings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-response-warnings']
---
import kbnSearchResponseWarningsObj from './kbn_search_response_warnings.devdocs.json';
diff --git a/api_docs/kbn_search_shared_ui.mdx b/api_docs/kbn_search_shared_ui.mdx
index 4bdafcccdcc9a..f234bdafcb187 100644
--- a/api_docs/kbn_search_shared_ui.mdx
+++ b/api_docs/kbn_search_shared_ui.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-shared-ui
title: "@kbn/search-shared-ui"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-shared-ui plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-shared-ui']
---
import kbnSearchSharedUiObj from './kbn_search_shared_ui.devdocs.json';
diff --git a/api_docs/kbn_search_types.mdx b/api_docs/kbn_search_types.mdx
index 50a2efa900442..9c0ec3604042d 100644
--- a/api_docs/kbn_search_types.mdx
+++ b/api_docs/kbn_search_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-search-types
title: "@kbn/search-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/search-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/search-types']
---
import kbnSearchTypesObj from './kbn_search_types.devdocs.json';
diff --git a/api_docs/kbn_security_api_key_management.mdx b/api_docs/kbn_security_api_key_management.mdx
index 1c262f0d5c355..cc69e96f4a303 100644
--- a/api_docs/kbn_security_api_key_management.mdx
+++ b/api_docs/kbn_security_api_key_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-api-key-management
title: "@kbn/security-api-key-management"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-api-key-management plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-api-key-management']
---
import kbnSecurityApiKeyManagementObj from './kbn_security_api_key_management.devdocs.json';
diff --git a/api_docs/kbn_security_authorization_core.mdx b/api_docs/kbn_security_authorization_core.mdx
index dc1de6d7c295a..0791f1f828995 100644
--- a/api_docs/kbn_security_authorization_core.mdx
+++ b/api_docs/kbn_security_authorization_core.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-authorization-core
title: "@kbn/security-authorization-core"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-authorization-core plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-authorization-core']
---
import kbnSecurityAuthorizationCoreObj from './kbn_security_authorization_core.devdocs.json';
diff --git a/api_docs/kbn_security_authorization_core_common.mdx b/api_docs/kbn_security_authorization_core_common.mdx
index efd9c773c5caa..de0d6177396a9 100644
--- a/api_docs/kbn_security_authorization_core_common.mdx
+++ b/api_docs/kbn_security_authorization_core_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-authorization-core-common
title: "@kbn/security-authorization-core-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-authorization-core-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-authorization-core-common']
---
import kbnSecurityAuthorizationCoreCommonObj from './kbn_security_authorization_core_common.devdocs.json';
diff --git a/api_docs/kbn_security_form_components.mdx b/api_docs/kbn_security_form_components.mdx
index a2f3c2324ee37..2171b7fd04847 100644
--- a/api_docs/kbn_security_form_components.mdx
+++ b/api_docs/kbn_security_form_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-form-components
title: "@kbn/security-form-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-form-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-form-components']
---
import kbnSecurityFormComponentsObj from './kbn_security_form_components.devdocs.json';
diff --git a/api_docs/kbn_security_hardening.mdx b/api_docs/kbn_security_hardening.mdx
index 8a3ae3b452613..8a8fbc46867bb 100644
--- a/api_docs/kbn_security_hardening.mdx
+++ b/api_docs/kbn_security_hardening.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-hardening
title: "@kbn/security-hardening"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-hardening plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-hardening']
---
import kbnSecurityHardeningObj from './kbn_security_hardening.devdocs.json';
diff --git a/api_docs/kbn_security_plugin_types_common.mdx b/api_docs/kbn_security_plugin_types_common.mdx
index 9f184d8609794..d314a73b2caee 100644
--- a/api_docs/kbn_security_plugin_types_common.mdx
+++ b/api_docs/kbn_security_plugin_types_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-plugin-types-common
title: "@kbn/security-plugin-types-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-plugin-types-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-plugin-types-common']
---
import kbnSecurityPluginTypesCommonObj from './kbn_security_plugin_types_common.devdocs.json';
diff --git a/api_docs/kbn_security_plugin_types_public.mdx b/api_docs/kbn_security_plugin_types_public.mdx
index 3546c48b5dd73..007ed562d7000 100644
--- a/api_docs/kbn_security_plugin_types_public.mdx
+++ b/api_docs/kbn_security_plugin_types_public.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-plugin-types-public
title: "@kbn/security-plugin-types-public"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-plugin-types-public plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-plugin-types-public']
---
import kbnSecurityPluginTypesPublicObj from './kbn_security_plugin_types_public.devdocs.json';
diff --git a/api_docs/kbn_security_plugin_types_server.mdx b/api_docs/kbn_security_plugin_types_server.mdx
index 26712a4c63bba..601b84564ea12 100644
--- a/api_docs/kbn_security_plugin_types_server.mdx
+++ b/api_docs/kbn_security_plugin_types_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-plugin-types-server
title: "@kbn/security-plugin-types-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-plugin-types-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-plugin-types-server']
---
import kbnSecurityPluginTypesServerObj from './kbn_security_plugin_types_server.devdocs.json';
diff --git a/api_docs/kbn_security_role_management_model.mdx b/api_docs/kbn_security_role_management_model.mdx
index 601da769abe79..11f2e5902e207 100644
--- a/api_docs/kbn_security_role_management_model.mdx
+++ b/api_docs/kbn_security_role_management_model.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-role-management-model
title: "@kbn/security-role-management-model"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-role-management-model plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-role-management-model']
---
import kbnSecurityRoleManagementModelObj from './kbn_security_role_management_model.devdocs.json';
diff --git a/api_docs/kbn_security_solution_common.mdx b/api_docs/kbn_security_solution_common.mdx
index be581a0fbfa42..fc824e0022af7 100644
--- a/api_docs/kbn_security_solution_common.mdx
+++ b/api_docs/kbn_security_solution_common.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-solution-common
title: "@kbn/security-solution-common"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-solution-common plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-solution-common']
---
import kbnSecuritySolutionCommonObj from './kbn_security_solution_common.devdocs.json';
diff --git a/api_docs/kbn_security_solution_distribution_bar.mdx b/api_docs/kbn_security_solution_distribution_bar.mdx
index 2fc70e7abd90b..bf7082f370ba3 100644
--- a/api_docs/kbn_security_solution_distribution_bar.mdx
+++ b/api_docs/kbn_security_solution_distribution_bar.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-solution-distribution-bar
title: "@kbn/security-solution-distribution-bar"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-solution-distribution-bar plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-solution-distribution-bar']
---
import kbnSecuritySolutionDistributionBarObj from './kbn_security_solution_distribution_bar.devdocs.json';
diff --git a/api_docs/kbn_security_solution_features.mdx b/api_docs/kbn_security_solution_features.mdx
index 5b77fc3e5a468..91af6943af9b9 100644
--- a/api_docs/kbn_security_solution_features.mdx
+++ b/api_docs/kbn_security_solution_features.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-solution-features
title: "@kbn/security-solution-features"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-solution-features plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-solution-features']
---
import kbnSecuritySolutionFeaturesObj from './kbn_security_solution_features.devdocs.json';
diff --git a/api_docs/kbn_security_solution_navigation.mdx b/api_docs/kbn_security_solution_navigation.mdx
index 421d29e8e982f..21980402ee2b0 100644
--- a/api_docs/kbn_security_solution_navigation.mdx
+++ b/api_docs/kbn_security_solution_navigation.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-solution-navigation
title: "@kbn/security-solution-navigation"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-solution-navigation plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-solution-navigation']
---
import kbnSecuritySolutionNavigationObj from './kbn_security_solution_navigation.devdocs.json';
diff --git a/api_docs/kbn_security_solution_side_nav.mdx b/api_docs/kbn_security_solution_side_nav.mdx
index ec532f395974d..090eb92ac5e95 100644
--- a/api_docs/kbn_security_solution_side_nav.mdx
+++ b/api_docs/kbn_security_solution_side_nav.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-solution-side-nav
title: "@kbn/security-solution-side-nav"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-solution-side-nav plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-solution-side-nav']
---
import kbnSecuritySolutionSideNavObj from './kbn_security_solution_side_nav.devdocs.json';
diff --git a/api_docs/kbn_security_solution_storybook_config.mdx b/api_docs/kbn_security_solution_storybook_config.mdx
index bdbff0d68f581..07deee1fbe40d 100644
--- a/api_docs/kbn_security_solution_storybook_config.mdx
+++ b/api_docs/kbn_security_solution_storybook_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-solution-storybook-config
title: "@kbn/security-solution-storybook-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-solution-storybook-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-solution-storybook-config']
---
import kbnSecuritySolutionStorybookConfigObj from './kbn_security_solution_storybook_config.devdocs.json';
diff --git a/api_docs/kbn_security_ui_components.mdx b/api_docs/kbn_security_ui_components.mdx
index 5c26eaa871c07..0c0ba6eed7892 100644
--- a/api_docs/kbn_security_ui_components.mdx
+++ b/api_docs/kbn_security_ui_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-security-ui-components
title: "@kbn/security-ui-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/security-ui-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/security-ui-components']
---
import kbnSecurityUiComponentsObj from './kbn_security_ui_components.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_autocomplete.mdx b/api_docs/kbn_securitysolution_autocomplete.mdx
index ba5d77ecc551a..a34cdae4cd97e 100644
--- a/api_docs/kbn_securitysolution_autocomplete.mdx
+++ b/api_docs/kbn_securitysolution_autocomplete.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-autocomplete
title: "@kbn/securitysolution-autocomplete"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-autocomplete plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-autocomplete']
---
import kbnSecuritysolutionAutocompleteObj from './kbn_securitysolution_autocomplete.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_data_table.mdx b/api_docs/kbn_securitysolution_data_table.mdx
index 2ec683edad458..688d50cef7ef6 100644
--- a/api_docs/kbn_securitysolution_data_table.mdx
+++ b/api_docs/kbn_securitysolution_data_table.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-data-table
title: "@kbn/securitysolution-data-table"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-data-table plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-data-table']
---
import kbnSecuritysolutionDataTableObj from './kbn_securitysolution_data_table.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_ecs.mdx b/api_docs/kbn_securitysolution_ecs.mdx
index d60c8a858170c..9e912e7b4ca1e 100644
--- a/api_docs/kbn_securitysolution_ecs.mdx
+++ b/api_docs/kbn_securitysolution_ecs.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-ecs
title: "@kbn/securitysolution-ecs"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-ecs plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-ecs']
---
import kbnSecuritysolutionEcsObj from './kbn_securitysolution_ecs.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_es_utils.mdx b/api_docs/kbn_securitysolution_es_utils.mdx
index ed97a48b1f538..0506493c5671c 100644
--- a/api_docs/kbn_securitysolution_es_utils.mdx
+++ b/api_docs/kbn_securitysolution_es_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-es-utils
title: "@kbn/securitysolution-es-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-es-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-es-utils']
---
import kbnSecuritysolutionEsUtilsObj from './kbn_securitysolution_es_utils.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_exception_list_components.mdx b/api_docs/kbn_securitysolution_exception_list_components.mdx
index e2d647cf322d0..eeb77f30fe24e 100644
--- a/api_docs/kbn_securitysolution_exception_list_components.mdx
+++ b/api_docs/kbn_securitysolution_exception_list_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-exception-list-components
title: "@kbn/securitysolution-exception-list-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-exception-list-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-exception-list-components']
---
import kbnSecuritysolutionExceptionListComponentsObj from './kbn_securitysolution_exception_list_components.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_hook_utils.mdx b/api_docs/kbn_securitysolution_hook_utils.mdx
index cb5d230fda8a5..93746138f79ce 100644
--- a/api_docs/kbn_securitysolution_hook_utils.mdx
+++ b/api_docs/kbn_securitysolution_hook_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-hook-utils
title: "@kbn/securitysolution-hook-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-hook-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-hook-utils']
---
import kbnSecuritysolutionHookUtilsObj from './kbn_securitysolution_hook_utils.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx b/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx
index f4322bdffe9a2..9ed507bccbff8 100644
--- a/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx
+++ b/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-alerting-types
title: "@kbn/securitysolution-io-ts-alerting-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-io-ts-alerting-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-alerting-types']
---
import kbnSecuritysolutionIoTsAlertingTypesObj from './kbn_securitysolution_io_ts_alerting_types.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_io_ts_list_types.mdx b/api_docs/kbn_securitysolution_io_ts_list_types.mdx
index 77dcb8655546e..9823ddedeec5a 100644
--- a/api_docs/kbn_securitysolution_io_ts_list_types.mdx
+++ b/api_docs/kbn_securitysolution_io_ts_list_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-list-types
title: "@kbn/securitysolution-io-ts-list-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-io-ts-list-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-list-types']
---
import kbnSecuritysolutionIoTsListTypesObj from './kbn_securitysolution_io_ts_list_types.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_io_ts_types.mdx b/api_docs/kbn_securitysolution_io_ts_types.mdx
index dd7621311f768..88e037ff0dfe3 100644
--- a/api_docs/kbn_securitysolution_io_ts_types.mdx
+++ b/api_docs/kbn_securitysolution_io_ts_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-types
title: "@kbn/securitysolution-io-ts-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-io-ts-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-types']
---
import kbnSecuritysolutionIoTsTypesObj from './kbn_securitysolution_io_ts_types.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_io_ts_utils.mdx b/api_docs/kbn_securitysolution_io_ts_utils.mdx
index dc2d2a3f55aff..f030a806aad3e 100644
--- a/api_docs/kbn_securitysolution_io_ts_utils.mdx
+++ b/api_docs/kbn_securitysolution_io_ts_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-utils
title: "@kbn/securitysolution-io-ts-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-io-ts-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-utils']
---
import kbnSecuritysolutionIoTsUtilsObj from './kbn_securitysolution_io_ts_utils.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_list_api.mdx b/api_docs/kbn_securitysolution_list_api.mdx
index 00d4ed55268a1..e0d4291b9d358 100644
--- a/api_docs/kbn_securitysolution_list_api.mdx
+++ b/api_docs/kbn_securitysolution_list_api.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-api
title: "@kbn/securitysolution-list-api"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-list-api plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-api']
---
import kbnSecuritysolutionListApiObj from './kbn_securitysolution_list_api.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_list_constants.mdx b/api_docs/kbn_securitysolution_list_constants.mdx
index c29c8a3f2b52d..e8a4cd491a806 100644
--- a/api_docs/kbn_securitysolution_list_constants.mdx
+++ b/api_docs/kbn_securitysolution_list_constants.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-constants
title: "@kbn/securitysolution-list-constants"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-list-constants plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-constants']
---
import kbnSecuritysolutionListConstantsObj from './kbn_securitysolution_list_constants.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_list_hooks.mdx b/api_docs/kbn_securitysolution_list_hooks.mdx
index 47db6d7a6991c..c4f10307a4e33 100644
--- a/api_docs/kbn_securitysolution_list_hooks.mdx
+++ b/api_docs/kbn_securitysolution_list_hooks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-hooks
title: "@kbn/securitysolution-list-hooks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-list-hooks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-hooks']
---
import kbnSecuritysolutionListHooksObj from './kbn_securitysolution_list_hooks.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_list_utils.mdx b/api_docs/kbn_securitysolution_list_utils.mdx
index 5937b4f4a7fb3..131a46fd1e32e 100644
--- a/api_docs/kbn_securitysolution_list_utils.mdx
+++ b/api_docs/kbn_securitysolution_list_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-utils
title: "@kbn/securitysolution-list-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-list-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-utils']
---
import kbnSecuritysolutionListUtilsObj from './kbn_securitysolution_list_utils.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_rules.mdx b/api_docs/kbn_securitysolution_rules.mdx
index 370e79d0d1226..f1607b93950a6 100644
--- a/api_docs/kbn_securitysolution_rules.mdx
+++ b/api_docs/kbn_securitysolution_rules.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-rules
title: "@kbn/securitysolution-rules"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-rules plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-rules']
---
import kbnSecuritysolutionRulesObj from './kbn_securitysolution_rules.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_t_grid.mdx b/api_docs/kbn_securitysolution_t_grid.mdx
index fe83018b06412..74a80665ed684 100644
--- a/api_docs/kbn_securitysolution_t_grid.mdx
+++ b/api_docs/kbn_securitysolution_t_grid.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-t-grid
title: "@kbn/securitysolution-t-grid"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-t-grid plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-t-grid']
---
import kbnSecuritysolutionTGridObj from './kbn_securitysolution_t_grid.devdocs.json';
diff --git a/api_docs/kbn_securitysolution_utils.mdx b/api_docs/kbn_securitysolution_utils.mdx
index 150c5ecc84909..a82d6f50a167e 100644
--- a/api_docs/kbn_securitysolution_utils.mdx
+++ b/api_docs/kbn_securitysolution_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-utils
title: "@kbn/securitysolution-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/securitysolution-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-utils']
---
import kbnSecuritysolutionUtilsObj from './kbn_securitysolution_utils.devdocs.json';
diff --git a/api_docs/kbn_server_http_tools.mdx b/api_docs/kbn_server_http_tools.mdx
index 8fbdd9d8e2ef9..245a8bfead558 100644
--- a/api_docs/kbn_server_http_tools.mdx
+++ b/api_docs/kbn_server_http_tools.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-server-http-tools
title: "@kbn/server-http-tools"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/server-http-tools plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/server-http-tools']
---
import kbnServerHttpToolsObj from './kbn_server_http_tools.devdocs.json';
diff --git a/api_docs/kbn_server_route_repository.mdx b/api_docs/kbn_server_route_repository.mdx
index 0b3d79af9bd06..4405956f486bd 100644
--- a/api_docs/kbn_server_route_repository.mdx
+++ b/api_docs/kbn_server_route_repository.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-server-route-repository
title: "@kbn/server-route-repository"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/server-route-repository plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/server-route-repository']
---
import kbnServerRouteRepositoryObj from './kbn_server_route_repository.devdocs.json';
diff --git a/api_docs/kbn_server_route_repository_client.mdx b/api_docs/kbn_server_route_repository_client.mdx
index a817b64ffd389..1b33d0a5d620a 100644
--- a/api_docs/kbn_server_route_repository_client.mdx
+++ b/api_docs/kbn_server_route_repository_client.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-server-route-repository-client
title: "@kbn/server-route-repository-client"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/server-route-repository-client plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/server-route-repository-client']
---
import kbnServerRouteRepositoryClientObj from './kbn_server_route_repository_client.devdocs.json';
diff --git a/api_docs/kbn_server_route_repository_utils.mdx b/api_docs/kbn_server_route_repository_utils.mdx
index 9c7d2c25b47bb..9ed8b6776b8f8 100644
--- a/api_docs/kbn_server_route_repository_utils.mdx
+++ b/api_docs/kbn_server_route_repository_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-server-route-repository-utils
title: "@kbn/server-route-repository-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/server-route-repository-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/server-route-repository-utils']
---
import kbnServerRouteRepositoryUtilsObj from './kbn_server_route_repository_utils.devdocs.json';
diff --git a/api_docs/kbn_serverless_common_settings.mdx b/api_docs/kbn_serverless_common_settings.mdx
index 1bdfa310af4db..07516adc07f21 100644
--- a/api_docs/kbn_serverless_common_settings.mdx
+++ b/api_docs/kbn_serverless_common_settings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-serverless-common-settings
title: "@kbn/serverless-common-settings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/serverless-common-settings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/serverless-common-settings']
---
import kbnServerlessCommonSettingsObj from './kbn_serverless_common_settings.devdocs.json';
diff --git a/api_docs/kbn_serverless_observability_settings.mdx b/api_docs/kbn_serverless_observability_settings.mdx
index 52701d1aef5d4..6e5fa8dafc28f 100644
--- a/api_docs/kbn_serverless_observability_settings.mdx
+++ b/api_docs/kbn_serverless_observability_settings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-serverless-observability-settings
title: "@kbn/serverless-observability-settings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/serverless-observability-settings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/serverless-observability-settings']
---
import kbnServerlessObservabilitySettingsObj from './kbn_serverless_observability_settings.devdocs.json';
diff --git a/api_docs/kbn_serverless_project_switcher.mdx b/api_docs/kbn_serverless_project_switcher.mdx
index 1d350f1a3f2bf..25501cf1d0f0a 100644
--- a/api_docs/kbn_serverless_project_switcher.mdx
+++ b/api_docs/kbn_serverless_project_switcher.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-serverless-project-switcher
title: "@kbn/serverless-project-switcher"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/serverless-project-switcher plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/serverless-project-switcher']
---
import kbnServerlessProjectSwitcherObj from './kbn_serverless_project_switcher.devdocs.json';
diff --git a/api_docs/kbn_serverless_search_settings.mdx b/api_docs/kbn_serverless_search_settings.mdx
index a5a42778f8e0c..a87d84e1355da 100644
--- a/api_docs/kbn_serverless_search_settings.mdx
+++ b/api_docs/kbn_serverless_search_settings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-serverless-search-settings
title: "@kbn/serverless-search-settings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/serverless-search-settings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/serverless-search-settings']
---
import kbnServerlessSearchSettingsObj from './kbn_serverless_search_settings.devdocs.json';
diff --git a/api_docs/kbn_serverless_security_settings.mdx b/api_docs/kbn_serverless_security_settings.mdx
index b7886a1e058a7..661f41b13ea65 100644
--- a/api_docs/kbn_serverless_security_settings.mdx
+++ b/api_docs/kbn_serverless_security_settings.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-serverless-security-settings
title: "@kbn/serverless-security-settings"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/serverless-security-settings plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/serverless-security-settings']
---
import kbnServerlessSecuritySettingsObj from './kbn_serverless_security_settings.devdocs.json';
diff --git a/api_docs/kbn_serverless_storybook_config.mdx b/api_docs/kbn_serverless_storybook_config.mdx
index 4f480e994ecdd..7cc8d43a3f58a 100644
--- a/api_docs/kbn_serverless_storybook_config.mdx
+++ b/api_docs/kbn_serverless_storybook_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-serverless-storybook-config
title: "@kbn/serverless-storybook-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/serverless-storybook-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/serverless-storybook-config']
---
import kbnServerlessStorybookConfigObj from './kbn_serverless_storybook_config.devdocs.json';
diff --git a/api_docs/kbn_shared_svg.mdx b/api_docs/kbn_shared_svg.mdx
index 9a4b6cdf2c0fe..4c5cded5d92cd 100644
--- a/api_docs/kbn_shared_svg.mdx
+++ b/api_docs/kbn_shared_svg.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-svg
title: "@kbn/shared-svg"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-svg plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-svg']
---
import kbnSharedSvgObj from './kbn_shared_svg.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_avatar_solution.mdx b/api_docs/kbn_shared_ux_avatar_solution.mdx
index 0fd87f7e2a29b..3e73d0fbed46d 100644
--- a/api_docs/kbn_shared_ux_avatar_solution.mdx
+++ b/api_docs/kbn_shared_ux_avatar_solution.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-avatar-solution
title: "@kbn/shared-ux-avatar-solution"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-avatar-solution plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-avatar-solution']
---
import kbnSharedUxAvatarSolutionObj from './kbn_shared_ux_avatar_solution.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_button_exit_full_screen.mdx b/api_docs/kbn_shared_ux_button_exit_full_screen.mdx
index 4ab8780e3d0f8..cbf6ea28eab00 100644
--- a/api_docs/kbn_shared_ux_button_exit_full_screen.mdx
+++ b/api_docs/kbn_shared_ux_button_exit_full_screen.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-button-exit-full-screen
title: "@kbn/shared-ux-button-exit-full-screen"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-button-exit-full-screen plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-button-exit-full-screen']
---
import kbnSharedUxButtonExitFullScreenObj from './kbn_shared_ux_button_exit_full_screen.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_button_toolbar.mdx b/api_docs/kbn_shared_ux_button_toolbar.mdx
index ef6f69a43e8cb..a356bac755a7b 100644
--- a/api_docs/kbn_shared_ux_button_toolbar.mdx
+++ b/api_docs/kbn_shared_ux_button_toolbar.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-button-toolbar
title: "@kbn/shared-ux-button-toolbar"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-button-toolbar plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-button-toolbar']
---
import kbnSharedUxButtonToolbarObj from './kbn_shared_ux_button_toolbar.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_card_no_data.mdx b/api_docs/kbn_shared_ux_card_no_data.mdx
index 30b029f2a4146..8425949a390a4 100644
--- a/api_docs/kbn_shared_ux_card_no_data.mdx
+++ b/api_docs/kbn_shared_ux_card_no_data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-card-no-data
title: "@kbn/shared-ux-card-no-data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-card-no-data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-card-no-data']
---
import kbnSharedUxCardNoDataObj from './kbn_shared_ux_card_no_data.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_card_no_data_mocks.mdx b/api_docs/kbn_shared_ux_card_no_data_mocks.mdx
index 8ea85afcf5d73..465e2f2aa97d0 100644
--- a/api_docs/kbn_shared_ux_card_no_data_mocks.mdx
+++ b/api_docs/kbn_shared_ux_card_no_data_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-card-no-data-mocks
title: "@kbn/shared-ux-card-no-data-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-card-no-data-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-card-no-data-mocks']
---
import kbnSharedUxCardNoDataMocksObj from './kbn_shared_ux_card_no_data_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_chrome_navigation.mdx b/api_docs/kbn_shared_ux_chrome_navigation.mdx
index 2a090db51698c..28d72aa35391e 100644
--- a/api_docs/kbn_shared_ux_chrome_navigation.mdx
+++ b/api_docs/kbn_shared_ux_chrome_navigation.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-chrome-navigation
title: "@kbn/shared-ux-chrome-navigation"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-chrome-navigation plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-chrome-navigation']
---
import kbnSharedUxChromeNavigationObj from './kbn_shared_ux_chrome_navigation.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_error_boundary.mdx b/api_docs/kbn_shared_ux_error_boundary.mdx
index a78d87f716756..16fe52f50c9d6 100644
--- a/api_docs/kbn_shared_ux_error_boundary.mdx
+++ b/api_docs/kbn_shared_ux_error_boundary.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-error-boundary
title: "@kbn/shared-ux-error-boundary"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-error-boundary plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-error-boundary']
---
import kbnSharedUxErrorBoundaryObj from './kbn_shared_ux_error_boundary.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_context.mdx b/api_docs/kbn_shared_ux_file_context.mdx
index 4f6be0f093ba7..51f1f66418391 100644
--- a/api_docs/kbn_shared_ux_file_context.mdx
+++ b/api_docs/kbn_shared_ux_file_context.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-context
title: "@kbn/shared-ux-file-context"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-context plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-context']
---
import kbnSharedUxFileContextObj from './kbn_shared_ux_file_context.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_image.mdx b/api_docs/kbn_shared_ux_file_image.mdx
index 8ca2ba1e0eee9..2d9aacf8b6e8d 100644
--- a/api_docs/kbn_shared_ux_file_image.mdx
+++ b/api_docs/kbn_shared_ux_file_image.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-image
title: "@kbn/shared-ux-file-image"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-image plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-image']
---
import kbnSharedUxFileImageObj from './kbn_shared_ux_file_image.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_image_mocks.mdx b/api_docs/kbn_shared_ux_file_image_mocks.mdx
index c6e29fcb81517..54c201bd0ee91 100644
--- a/api_docs/kbn_shared_ux_file_image_mocks.mdx
+++ b/api_docs/kbn_shared_ux_file_image_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-image-mocks
title: "@kbn/shared-ux-file-image-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-image-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-image-mocks']
---
import kbnSharedUxFileImageMocksObj from './kbn_shared_ux_file_image_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_mocks.mdx b/api_docs/kbn_shared_ux_file_mocks.mdx
index e1a18247db2b2..32a02ee12ef00 100644
--- a/api_docs/kbn_shared_ux_file_mocks.mdx
+++ b/api_docs/kbn_shared_ux_file_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-mocks
title: "@kbn/shared-ux-file-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-mocks']
---
import kbnSharedUxFileMocksObj from './kbn_shared_ux_file_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_picker.mdx b/api_docs/kbn_shared_ux_file_picker.mdx
index 2128cd6a7da87..1c6ac8dab7628 100644
--- a/api_docs/kbn_shared_ux_file_picker.mdx
+++ b/api_docs/kbn_shared_ux_file_picker.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-picker
title: "@kbn/shared-ux-file-picker"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-picker plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-picker']
---
import kbnSharedUxFilePickerObj from './kbn_shared_ux_file_picker.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_types.mdx b/api_docs/kbn_shared_ux_file_types.mdx
index f6a7e82cad21b..f78223e9bbb9b 100644
--- a/api_docs/kbn_shared_ux_file_types.mdx
+++ b/api_docs/kbn_shared_ux_file_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-types
title: "@kbn/shared-ux-file-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-types']
---
import kbnSharedUxFileTypesObj from './kbn_shared_ux_file_types.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_upload.mdx b/api_docs/kbn_shared_ux_file_upload.mdx
index 5251874b86d23..ff06190ef3e26 100644
--- a/api_docs/kbn_shared_ux_file_upload.mdx
+++ b/api_docs/kbn_shared_ux_file_upload.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-upload
title: "@kbn/shared-ux-file-upload"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-upload plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-upload']
---
import kbnSharedUxFileUploadObj from './kbn_shared_ux_file_upload.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_file_util.mdx b/api_docs/kbn_shared_ux_file_util.mdx
index 4d6ecb930b57c..03c853a3fa229 100644
--- a/api_docs/kbn_shared_ux_file_util.mdx
+++ b/api_docs/kbn_shared_ux_file_util.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-file-util
title: "@kbn/shared-ux-file-util"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-file-util plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-file-util']
---
import kbnSharedUxFileUtilObj from './kbn_shared_ux_file_util.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_link_redirect_app.mdx b/api_docs/kbn_shared_ux_link_redirect_app.mdx
index f061546274d0d..86a9751d0892c 100644
--- a/api_docs/kbn_shared_ux_link_redirect_app.mdx
+++ b/api_docs/kbn_shared_ux_link_redirect_app.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-link-redirect-app
title: "@kbn/shared-ux-link-redirect-app"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-link-redirect-app plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-link-redirect-app']
---
import kbnSharedUxLinkRedirectAppObj from './kbn_shared_ux_link_redirect_app.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_link_redirect_app_mocks.mdx b/api_docs/kbn_shared_ux_link_redirect_app_mocks.mdx
index ce2157a09025e..038c3b9b02fa8 100644
--- a/api_docs/kbn_shared_ux_link_redirect_app_mocks.mdx
+++ b/api_docs/kbn_shared_ux_link_redirect_app_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-link-redirect-app-mocks
title: "@kbn/shared-ux-link-redirect-app-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-link-redirect-app-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-link-redirect-app-mocks']
---
import kbnSharedUxLinkRedirectAppMocksObj from './kbn_shared_ux_link_redirect_app_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_markdown.mdx b/api_docs/kbn_shared_ux_markdown.mdx
index f69516955b203..48fe1aace774a 100644
--- a/api_docs/kbn_shared_ux_markdown.mdx
+++ b/api_docs/kbn_shared_ux_markdown.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-markdown
title: "@kbn/shared-ux-markdown"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-markdown plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-markdown']
---
import kbnSharedUxMarkdownObj from './kbn_shared_ux_markdown.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_markdown_mocks.mdx b/api_docs/kbn_shared_ux_markdown_mocks.mdx
index bf60d1bb11999..987b8a3ef6c0c 100644
--- a/api_docs/kbn_shared_ux_markdown_mocks.mdx
+++ b/api_docs/kbn_shared_ux_markdown_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-markdown-mocks
title: "@kbn/shared-ux-markdown-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-markdown-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-markdown-mocks']
---
import kbnSharedUxMarkdownMocksObj from './kbn_shared_ux_markdown_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_analytics_no_data.mdx b/api_docs/kbn_shared_ux_page_analytics_no_data.mdx
index d7a83d54eea92..71206803df2b4 100644
--- a/api_docs/kbn_shared_ux_page_analytics_no_data.mdx
+++ b/api_docs/kbn_shared_ux_page_analytics_no_data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-analytics-no-data
title: "@kbn/shared-ux-page-analytics-no-data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-analytics-no-data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-analytics-no-data']
---
import kbnSharedUxPageAnalyticsNoDataObj from './kbn_shared_ux_page_analytics_no_data.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_analytics_no_data_mocks.mdx b/api_docs/kbn_shared_ux_page_analytics_no_data_mocks.mdx
index b8fba26493a1e..e48c1dac9f021 100644
--- a/api_docs/kbn_shared_ux_page_analytics_no_data_mocks.mdx
+++ b/api_docs/kbn_shared_ux_page_analytics_no_data_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-analytics-no-data-mocks
title: "@kbn/shared-ux-page-analytics-no-data-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-analytics-no-data-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-analytics-no-data-mocks']
---
import kbnSharedUxPageAnalyticsNoDataMocksObj from './kbn_shared_ux_page_analytics_no_data_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_kibana_no_data.mdx b/api_docs/kbn_shared_ux_page_kibana_no_data.mdx
index 141dea6470f7b..4d154840f86c8 100644
--- a/api_docs/kbn_shared_ux_page_kibana_no_data.mdx
+++ b/api_docs/kbn_shared_ux_page_kibana_no_data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-kibana-no-data
title: "@kbn/shared-ux-page-kibana-no-data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-kibana-no-data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-kibana-no-data']
---
import kbnSharedUxPageKibanaNoDataObj from './kbn_shared_ux_page_kibana_no_data.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_kibana_no_data_mocks.mdx b/api_docs/kbn_shared_ux_page_kibana_no_data_mocks.mdx
index 17aa152a7d00a..d58ebe6ccd271 100644
--- a/api_docs/kbn_shared_ux_page_kibana_no_data_mocks.mdx
+++ b/api_docs/kbn_shared_ux_page_kibana_no_data_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-kibana-no-data-mocks
title: "@kbn/shared-ux-page-kibana-no-data-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-kibana-no-data-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-kibana-no-data-mocks']
---
import kbnSharedUxPageKibanaNoDataMocksObj from './kbn_shared_ux_page_kibana_no_data_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_kibana_template.mdx b/api_docs/kbn_shared_ux_page_kibana_template.mdx
index d567cd63fa74f..e66ec22c16460 100644
--- a/api_docs/kbn_shared_ux_page_kibana_template.mdx
+++ b/api_docs/kbn_shared_ux_page_kibana_template.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-kibana-template
title: "@kbn/shared-ux-page-kibana-template"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-kibana-template plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-kibana-template']
---
import kbnSharedUxPageKibanaTemplateObj from './kbn_shared_ux_page_kibana_template.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_kibana_template_mocks.mdx b/api_docs/kbn_shared_ux_page_kibana_template_mocks.mdx
index 7fc24519e9306..138b4418bfec7 100644
--- a/api_docs/kbn_shared_ux_page_kibana_template_mocks.mdx
+++ b/api_docs/kbn_shared_ux_page_kibana_template_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-kibana-template-mocks
title: "@kbn/shared-ux-page-kibana-template-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-kibana-template-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-kibana-template-mocks']
---
import kbnSharedUxPageKibanaTemplateMocksObj from './kbn_shared_ux_page_kibana_template_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_no_data.mdx b/api_docs/kbn_shared_ux_page_no_data.mdx
index 7df919b082de3..3fb5c2fb91fca 100644
--- a/api_docs/kbn_shared_ux_page_no_data.mdx
+++ b/api_docs/kbn_shared_ux_page_no_data.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-no-data
title: "@kbn/shared-ux-page-no-data"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-no-data plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-no-data']
---
import kbnSharedUxPageNoDataObj from './kbn_shared_ux_page_no_data.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_no_data_config.mdx b/api_docs/kbn_shared_ux_page_no_data_config.mdx
index ef6a7be3be1c8..782dd0d9230d9 100644
--- a/api_docs/kbn_shared_ux_page_no_data_config.mdx
+++ b/api_docs/kbn_shared_ux_page_no_data_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-no-data-config
title: "@kbn/shared-ux-page-no-data-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-no-data-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-no-data-config']
---
import kbnSharedUxPageNoDataConfigObj from './kbn_shared_ux_page_no_data_config.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_no_data_config_mocks.mdx b/api_docs/kbn_shared_ux_page_no_data_config_mocks.mdx
index b3d812d3caa9c..f05dcb7155712 100644
--- a/api_docs/kbn_shared_ux_page_no_data_config_mocks.mdx
+++ b/api_docs/kbn_shared_ux_page_no_data_config_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-no-data-config-mocks
title: "@kbn/shared-ux-page-no-data-config-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-no-data-config-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-no-data-config-mocks']
---
import kbnSharedUxPageNoDataConfigMocksObj from './kbn_shared_ux_page_no_data_config_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_no_data_mocks.mdx b/api_docs/kbn_shared_ux_page_no_data_mocks.mdx
index 513502f230b46..9fa4b1da29dc8 100644
--- a/api_docs/kbn_shared_ux_page_no_data_mocks.mdx
+++ b/api_docs/kbn_shared_ux_page_no_data_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-no-data-mocks
title: "@kbn/shared-ux-page-no-data-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-no-data-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-no-data-mocks']
---
import kbnSharedUxPageNoDataMocksObj from './kbn_shared_ux_page_no_data_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_page_solution_nav.mdx b/api_docs/kbn_shared_ux_page_solution_nav.mdx
index 2e96be3d0c366..348bab44d9075 100644
--- a/api_docs/kbn_shared_ux_page_solution_nav.mdx
+++ b/api_docs/kbn_shared_ux_page_solution_nav.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-page-solution-nav
title: "@kbn/shared-ux-page-solution-nav"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-page-solution-nav plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-page-solution-nav']
---
import kbnSharedUxPageSolutionNavObj from './kbn_shared_ux_page_solution_nav.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_prompt_no_data_views.mdx b/api_docs/kbn_shared_ux_prompt_no_data_views.mdx
index 640e7d907c7cc..75097100f2914 100644
--- a/api_docs/kbn_shared_ux_prompt_no_data_views.mdx
+++ b/api_docs/kbn_shared_ux_prompt_no_data_views.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-prompt-no-data-views
title: "@kbn/shared-ux-prompt-no-data-views"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-prompt-no-data-views plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-prompt-no-data-views']
---
import kbnSharedUxPromptNoDataViewsObj from './kbn_shared_ux_prompt_no_data_views.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_prompt_no_data_views_mocks.mdx b/api_docs/kbn_shared_ux_prompt_no_data_views_mocks.mdx
index e90ade195bcf6..9507d6df6886b 100644
--- a/api_docs/kbn_shared_ux_prompt_no_data_views_mocks.mdx
+++ b/api_docs/kbn_shared_ux_prompt_no_data_views_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-prompt-no-data-views-mocks
title: "@kbn/shared-ux-prompt-no-data-views-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-prompt-no-data-views-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-prompt-no-data-views-mocks']
---
import kbnSharedUxPromptNoDataViewsMocksObj from './kbn_shared_ux_prompt_no_data_views_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_prompt_not_found.mdx b/api_docs/kbn_shared_ux_prompt_not_found.mdx
index c8905e33bd4b9..f775b22d60b20 100644
--- a/api_docs/kbn_shared_ux_prompt_not_found.mdx
+++ b/api_docs/kbn_shared_ux_prompt_not_found.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-prompt-not-found
title: "@kbn/shared-ux-prompt-not-found"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-prompt-not-found plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-prompt-not-found']
---
import kbnSharedUxPromptNotFoundObj from './kbn_shared_ux_prompt_not_found.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_router.mdx b/api_docs/kbn_shared_ux_router.mdx
index ebaefb6a8a5b5..6991ee456815d 100644
--- a/api_docs/kbn_shared_ux_router.mdx
+++ b/api_docs/kbn_shared_ux_router.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-router
title: "@kbn/shared-ux-router"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-router plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-router']
---
import kbnSharedUxRouterObj from './kbn_shared_ux_router.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_router_mocks.mdx b/api_docs/kbn_shared_ux_router_mocks.mdx
index 1fd5f952c37f5..4f71798957da0 100644
--- a/api_docs/kbn_shared_ux_router_mocks.mdx
+++ b/api_docs/kbn_shared_ux_router_mocks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-router-mocks
title: "@kbn/shared-ux-router-mocks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-router-mocks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-router-mocks']
---
import kbnSharedUxRouterMocksObj from './kbn_shared_ux_router_mocks.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_storybook_config.mdx b/api_docs/kbn_shared_ux_storybook_config.mdx
index 756e559ae3c4f..ec4404508a9b6 100644
--- a/api_docs/kbn_shared_ux_storybook_config.mdx
+++ b/api_docs/kbn_shared_ux_storybook_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-storybook-config
title: "@kbn/shared-ux-storybook-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-storybook-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-storybook-config']
---
import kbnSharedUxStorybookConfigObj from './kbn_shared_ux_storybook_config.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_storybook_mock.mdx b/api_docs/kbn_shared_ux_storybook_mock.mdx
index b87e1726a27af..a88bf327d9255 100644
--- a/api_docs/kbn_shared_ux_storybook_mock.mdx
+++ b/api_docs/kbn_shared_ux_storybook_mock.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-storybook-mock
title: "@kbn/shared-ux-storybook-mock"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-storybook-mock plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-storybook-mock']
---
import kbnSharedUxStorybookMockObj from './kbn_shared_ux_storybook_mock.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_tabbed_modal.mdx b/api_docs/kbn_shared_ux_tabbed_modal.mdx
index 76b850a14c617..7e74b886199c9 100644
--- a/api_docs/kbn_shared_ux_tabbed_modal.mdx
+++ b/api_docs/kbn_shared_ux_tabbed_modal.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-tabbed-modal
title: "@kbn/shared-ux-tabbed-modal"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-tabbed-modal plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-tabbed-modal']
---
import kbnSharedUxTabbedModalObj from './kbn_shared_ux_tabbed_modal.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_table_persist.mdx b/api_docs/kbn_shared_ux_table_persist.mdx
index a0977efebbd85..3ebc91a806e43 100644
--- a/api_docs/kbn_shared_ux_table_persist.mdx
+++ b/api_docs/kbn_shared_ux_table_persist.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-table-persist
title: "@kbn/shared-ux-table-persist"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-table-persist plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-table-persist']
---
import kbnSharedUxTablePersistObj from './kbn_shared_ux_table_persist.devdocs.json';
diff --git a/api_docs/kbn_shared_ux_utility.mdx b/api_docs/kbn_shared_ux_utility.mdx
index 334c81efa390b..8b64311a3bc1c 100644
--- a/api_docs/kbn_shared_ux_utility.mdx
+++ b/api_docs/kbn_shared_ux_utility.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-shared-ux-utility
title: "@kbn/shared-ux-utility"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/shared-ux-utility plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-utility']
---
import kbnSharedUxUtilityObj from './kbn_shared_ux_utility.devdocs.json';
diff --git a/api_docs/kbn_slo_schema.mdx b/api_docs/kbn_slo_schema.mdx
index a48e5f984e9b1..287aa7feab0d7 100644
--- a/api_docs/kbn_slo_schema.mdx
+++ b/api_docs/kbn_slo_schema.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-slo-schema
title: "@kbn/slo-schema"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/slo-schema plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/slo-schema']
---
import kbnSloSchemaObj from './kbn_slo_schema.devdocs.json';
diff --git a/api_docs/kbn_some_dev_log.mdx b/api_docs/kbn_some_dev_log.mdx
index ae7484e76dfdf..5cf3a0dd0bbfc 100644
--- a/api_docs/kbn_some_dev_log.mdx
+++ b/api_docs/kbn_some_dev_log.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-some-dev-log
title: "@kbn/some-dev-log"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/some-dev-log plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/some-dev-log']
---
import kbnSomeDevLogObj from './kbn_some_dev_log.devdocs.json';
diff --git a/api_docs/kbn_sort_predicates.mdx b/api_docs/kbn_sort_predicates.mdx
index c5107da97ff1a..0f4411bc75653 100644
--- a/api_docs/kbn_sort_predicates.mdx
+++ b/api_docs/kbn_sort_predicates.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-sort-predicates
title: "@kbn/sort-predicates"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/sort-predicates plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/sort-predicates']
---
import kbnSortPredicatesObj from './kbn_sort_predicates.devdocs.json';
diff --git a/api_docs/kbn_sse_utils.mdx b/api_docs/kbn_sse_utils.mdx
index 3ae5026263f72..b0358835ed028 100644
--- a/api_docs/kbn_sse_utils.mdx
+++ b/api_docs/kbn_sse_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-sse-utils
title: "@kbn/sse-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/sse-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/sse-utils']
---
import kbnSseUtilsObj from './kbn_sse_utils.devdocs.json';
diff --git a/api_docs/kbn_sse_utils_client.mdx b/api_docs/kbn_sse_utils_client.mdx
index ba3dfa554f504..15db4cdbb294a 100644
--- a/api_docs/kbn_sse_utils_client.mdx
+++ b/api_docs/kbn_sse_utils_client.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-sse-utils-client
title: "@kbn/sse-utils-client"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/sse-utils-client plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/sse-utils-client']
---
import kbnSseUtilsClientObj from './kbn_sse_utils_client.devdocs.json';
diff --git a/api_docs/kbn_sse_utils_server.mdx b/api_docs/kbn_sse_utils_server.mdx
index c558e4fc91788..fe9d93cd64885 100644
--- a/api_docs/kbn_sse_utils_server.mdx
+++ b/api_docs/kbn_sse_utils_server.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-sse-utils-server
title: "@kbn/sse-utils-server"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/sse-utils-server plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/sse-utils-server']
---
import kbnSseUtilsServerObj from './kbn_sse_utils_server.devdocs.json';
diff --git a/api_docs/kbn_std.mdx b/api_docs/kbn_std.mdx
index 85cec4b72d991..50c821675c49f 100644
--- a/api_docs/kbn_std.mdx
+++ b/api_docs/kbn_std.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-std
title: "@kbn/std"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/std plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/std']
---
import kbnStdObj from './kbn_std.devdocs.json';
diff --git a/api_docs/kbn_stdio_dev_helpers.mdx b/api_docs/kbn_stdio_dev_helpers.mdx
index fd338d42ad8c7..a5c2340a22af4 100644
--- a/api_docs/kbn_stdio_dev_helpers.mdx
+++ b/api_docs/kbn_stdio_dev_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-stdio-dev-helpers
title: "@kbn/stdio-dev-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/stdio-dev-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/stdio-dev-helpers']
---
import kbnStdioDevHelpersObj from './kbn_stdio_dev_helpers.devdocs.json';
diff --git a/api_docs/kbn_storybook.mdx b/api_docs/kbn_storybook.mdx
index 01052671efdaa..bde762c685b2a 100644
--- a/api_docs/kbn_storybook.mdx
+++ b/api_docs/kbn_storybook.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-storybook
title: "@kbn/storybook"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/storybook plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/storybook']
---
import kbnStorybookObj from './kbn_storybook.devdocs.json';
diff --git a/api_docs/kbn_synthetics_e2e.mdx b/api_docs/kbn_synthetics_e2e.mdx
index 907574c65af35..19165ea9a7ed5 100644
--- a/api_docs/kbn_synthetics_e2e.mdx
+++ b/api_docs/kbn_synthetics_e2e.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-synthetics-e2e
title: "@kbn/synthetics-e2e"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/synthetics-e2e plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/synthetics-e2e']
---
import kbnSyntheticsE2eObj from './kbn_synthetics_e2e.devdocs.json';
diff --git a/api_docs/kbn_synthetics_private_location.mdx b/api_docs/kbn_synthetics_private_location.mdx
index 9d4a816e6b168..b3f85536cd265 100644
--- a/api_docs/kbn_synthetics_private_location.mdx
+++ b/api_docs/kbn_synthetics_private_location.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-synthetics-private-location
title: "@kbn/synthetics-private-location"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/synthetics-private-location plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/synthetics-private-location']
---
import kbnSyntheticsPrivateLocationObj from './kbn_synthetics_private_location.devdocs.json';
diff --git a/api_docs/kbn_telemetry_tools.mdx b/api_docs/kbn_telemetry_tools.mdx
index 39aded96f85b5..60fe35e02977e 100644
--- a/api_docs/kbn_telemetry_tools.mdx
+++ b/api_docs/kbn_telemetry_tools.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-telemetry-tools
title: "@kbn/telemetry-tools"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/telemetry-tools plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/telemetry-tools']
---
import kbnTelemetryToolsObj from './kbn_telemetry_tools.devdocs.json';
diff --git a/api_docs/kbn_test.mdx b/api_docs/kbn_test.mdx
index 9db330a1634c6..ae0b8acfc0889 100644
--- a/api_docs/kbn_test.mdx
+++ b/api_docs/kbn_test.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-test
title: "@kbn/test"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/test plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/test']
---
import kbnTestObj from './kbn_test.devdocs.json';
diff --git a/api_docs/kbn_test_eui_helpers.mdx b/api_docs/kbn_test_eui_helpers.mdx
index c882a206e16e4..0eb79f1ee0123 100644
--- a/api_docs/kbn_test_eui_helpers.mdx
+++ b/api_docs/kbn_test_eui_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-test-eui-helpers
title: "@kbn/test-eui-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/test-eui-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/test-eui-helpers']
---
import kbnTestEuiHelpersObj from './kbn_test_eui_helpers.devdocs.json';
diff --git a/api_docs/kbn_test_jest_helpers.mdx b/api_docs/kbn_test_jest_helpers.mdx
index 686b6220a54a8..fa270cd46b39f 100644
--- a/api_docs/kbn_test_jest_helpers.mdx
+++ b/api_docs/kbn_test_jest_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-test-jest-helpers
title: "@kbn/test-jest-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/test-jest-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/test-jest-helpers']
---
import kbnTestJestHelpersObj from './kbn_test_jest_helpers.devdocs.json';
diff --git a/api_docs/kbn_test_subj_selector.mdx b/api_docs/kbn_test_subj_selector.mdx
index 3cbf220ed81c3..2ecff97eed975 100644
--- a/api_docs/kbn_test_subj_selector.mdx
+++ b/api_docs/kbn_test_subj_selector.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-test-subj-selector
title: "@kbn/test-subj-selector"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/test-subj-selector plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/test-subj-selector']
---
import kbnTestSubjSelectorObj from './kbn_test_subj_selector.devdocs.json';
diff --git a/api_docs/kbn_timerange.mdx b/api_docs/kbn_timerange.mdx
index 08b2e3a2d1b40..c9a47be6f3ef5 100644
--- a/api_docs/kbn_timerange.mdx
+++ b/api_docs/kbn_timerange.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-timerange
title: "@kbn/timerange"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/timerange plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/timerange']
---
import kbnTimerangeObj from './kbn_timerange.devdocs.json';
diff --git a/api_docs/kbn_tooling_log.mdx b/api_docs/kbn_tooling_log.mdx
index db8ed154e1947..58ae0394ee43d 100644
--- a/api_docs/kbn_tooling_log.mdx
+++ b/api_docs/kbn_tooling_log.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-tooling-log
title: "@kbn/tooling-log"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/tooling-log plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/tooling-log']
---
import kbnToolingLogObj from './kbn_tooling_log.devdocs.json';
diff --git a/api_docs/kbn_transpose_utils.mdx b/api_docs/kbn_transpose_utils.mdx
index f9a0f508afb92..aa14bce75a325 100644
--- a/api_docs/kbn_transpose_utils.mdx
+++ b/api_docs/kbn_transpose_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-transpose-utils
title: "@kbn/transpose-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/transpose-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/transpose-utils']
---
import kbnTransposeUtilsObj from './kbn_transpose_utils.devdocs.json';
diff --git a/api_docs/kbn_triggers_actions_ui_types.mdx b/api_docs/kbn_triggers_actions_ui_types.mdx
index 2db8f2e187913..4dfd7bb08056b 100644
--- a/api_docs/kbn_triggers_actions_ui_types.mdx
+++ b/api_docs/kbn_triggers_actions_ui_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-triggers-actions-ui-types
title: "@kbn/triggers-actions-ui-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/triggers-actions-ui-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/triggers-actions-ui-types']
---
import kbnTriggersActionsUiTypesObj from './kbn_triggers_actions_ui_types.devdocs.json';
diff --git a/api_docs/kbn_try_in_console.mdx b/api_docs/kbn_try_in_console.mdx
index 3f8ff9e6ddcfa..fa8142acfb18e 100644
--- a/api_docs/kbn_try_in_console.mdx
+++ b/api_docs/kbn_try_in_console.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-try-in-console
title: "@kbn/try-in-console"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/try-in-console plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/try-in-console']
---
import kbnTryInConsoleObj from './kbn_try_in_console.devdocs.json';
diff --git a/api_docs/kbn_ts_projects.mdx b/api_docs/kbn_ts_projects.mdx
index d748ff250001c..de8efb3ca7f1e 100644
--- a/api_docs/kbn_ts_projects.mdx
+++ b/api_docs/kbn_ts_projects.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ts-projects
title: "@kbn/ts-projects"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ts-projects plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ts-projects']
---
import kbnTsProjectsObj from './kbn_ts_projects.devdocs.json';
diff --git a/api_docs/kbn_typed_react_router_config.mdx b/api_docs/kbn_typed_react_router_config.mdx
index 771637a8dd929..94384e0d70098 100644
--- a/api_docs/kbn_typed_react_router_config.mdx
+++ b/api_docs/kbn_typed_react_router_config.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-typed-react-router-config
title: "@kbn/typed-react-router-config"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/typed-react-router-config plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/typed-react-router-config']
---
import kbnTypedReactRouterConfigObj from './kbn_typed_react_router_config.devdocs.json';
diff --git a/api_docs/kbn_ui_actions_browser.mdx b/api_docs/kbn_ui_actions_browser.mdx
index 1f4988314faa5..f8511aa29bfd2 100644
--- a/api_docs/kbn_ui_actions_browser.mdx
+++ b/api_docs/kbn_ui_actions_browser.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ui-actions-browser
title: "@kbn/ui-actions-browser"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ui-actions-browser plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ui-actions-browser']
---
import kbnUiActionsBrowserObj from './kbn_ui_actions_browser.devdocs.json';
diff --git a/api_docs/kbn_ui_shared_deps_src.mdx b/api_docs/kbn_ui_shared_deps_src.mdx
index 766e62453f6b9..8886d93c6ed20 100644
--- a/api_docs/kbn_ui_shared_deps_src.mdx
+++ b/api_docs/kbn_ui_shared_deps_src.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ui-shared-deps-src
title: "@kbn/ui-shared-deps-src"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ui-shared-deps-src plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ui-shared-deps-src']
---
import kbnUiSharedDepsSrcObj from './kbn_ui_shared_deps_src.devdocs.json';
diff --git a/api_docs/kbn_ui_theme.mdx b/api_docs/kbn_ui_theme.mdx
index cec74879f3bb3..0f435fe4d51a1 100644
--- a/api_docs/kbn_ui_theme.mdx
+++ b/api_docs/kbn_ui_theme.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-ui-theme
title: "@kbn/ui-theme"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/ui-theme plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ui-theme']
---
import kbnUiThemeObj from './kbn_ui_theme.devdocs.json';
diff --git a/api_docs/kbn_unified_data_table.mdx b/api_docs/kbn_unified_data_table.mdx
index 03bf17be83344..b7aaf9fc5e5eb 100644
--- a/api_docs/kbn_unified_data_table.mdx
+++ b/api_docs/kbn_unified_data_table.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-unified-data-table
title: "@kbn/unified-data-table"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/unified-data-table plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/unified-data-table']
---
import kbnUnifiedDataTableObj from './kbn_unified_data_table.devdocs.json';
diff --git a/api_docs/kbn_unified_doc_viewer.mdx b/api_docs/kbn_unified_doc_viewer.mdx
index 7e0e51a5b7a44..0d1f5386f06c5 100644
--- a/api_docs/kbn_unified_doc_viewer.mdx
+++ b/api_docs/kbn_unified_doc_viewer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-unified-doc-viewer
title: "@kbn/unified-doc-viewer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/unified-doc-viewer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/unified-doc-viewer']
---
import kbnUnifiedDocViewerObj from './kbn_unified_doc_viewer.devdocs.json';
diff --git a/api_docs/kbn_unified_field_list.mdx b/api_docs/kbn_unified_field_list.mdx
index 201cd12a31f2c..15cb0a4bc20d7 100644
--- a/api_docs/kbn_unified_field_list.mdx
+++ b/api_docs/kbn_unified_field_list.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-unified-field-list
title: "@kbn/unified-field-list"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/unified-field-list plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/unified-field-list']
---
import kbnUnifiedFieldListObj from './kbn_unified_field_list.devdocs.json';
diff --git a/api_docs/kbn_unsaved_changes_badge.mdx b/api_docs/kbn_unsaved_changes_badge.mdx
index 357b11d8c378c..b96e80c0095c8 100644
--- a/api_docs/kbn_unsaved_changes_badge.mdx
+++ b/api_docs/kbn_unsaved_changes_badge.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-unsaved-changes-badge
title: "@kbn/unsaved-changes-badge"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/unsaved-changes-badge plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/unsaved-changes-badge']
---
import kbnUnsavedChangesBadgeObj from './kbn_unsaved_changes_badge.devdocs.json';
diff --git a/api_docs/kbn_unsaved_changes_prompt.mdx b/api_docs/kbn_unsaved_changes_prompt.mdx
index 8eed09ee5ea85..ca11a0dc92703 100644
--- a/api_docs/kbn_unsaved_changes_prompt.mdx
+++ b/api_docs/kbn_unsaved_changes_prompt.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-unsaved-changes-prompt
title: "@kbn/unsaved-changes-prompt"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/unsaved-changes-prompt plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/unsaved-changes-prompt']
---
import kbnUnsavedChangesPromptObj from './kbn_unsaved_changes_prompt.devdocs.json';
diff --git a/api_docs/kbn_use_tracked_promise.mdx b/api_docs/kbn_use_tracked_promise.mdx
index b1776d554884e..7a233cb2eea87 100644
--- a/api_docs/kbn_use_tracked_promise.mdx
+++ b/api_docs/kbn_use_tracked_promise.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-use-tracked-promise
title: "@kbn/use-tracked-promise"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/use-tracked-promise plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/use-tracked-promise']
---
import kbnUseTrackedPromiseObj from './kbn_use_tracked_promise.devdocs.json';
diff --git a/api_docs/kbn_user_profile_components.mdx b/api_docs/kbn_user_profile_components.mdx
index f4597384f5365..fd1313146d3f4 100644
--- a/api_docs/kbn_user_profile_components.mdx
+++ b/api_docs/kbn_user_profile_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-user-profile-components
title: "@kbn/user-profile-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/user-profile-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/user-profile-components']
---
import kbnUserProfileComponentsObj from './kbn_user_profile_components.devdocs.json';
diff --git a/api_docs/kbn_utility_types.mdx b/api_docs/kbn_utility_types.mdx
index 40d95a5229c15..21ed092c0d0e3 100644
--- a/api_docs/kbn_utility_types.mdx
+++ b/api_docs/kbn_utility_types.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-utility-types
title: "@kbn/utility-types"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/utility-types plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/utility-types']
---
import kbnUtilityTypesObj from './kbn_utility_types.devdocs.json';
diff --git a/api_docs/kbn_utility_types_jest.mdx b/api_docs/kbn_utility_types_jest.mdx
index 7930e1cb58ada..ff420a4bcffb8 100644
--- a/api_docs/kbn_utility_types_jest.mdx
+++ b/api_docs/kbn_utility_types_jest.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-utility-types-jest
title: "@kbn/utility-types-jest"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/utility-types-jest plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/utility-types-jest']
---
import kbnUtilityTypesJestObj from './kbn_utility_types_jest.devdocs.json';
diff --git a/api_docs/kbn_utils.mdx b/api_docs/kbn_utils.mdx
index 913aa6a1c5a09..871a0bdfb5173 100644
--- a/api_docs/kbn_utils.mdx
+++ b/api_docs/kbn_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-utils
title: "@kbn/utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/utils']
---
import kbnUtilsObj from './kbn_utils.devdocs.json';
diff --git a/api_docs/kbn_visualization_ui_components.mdx b/api_docs/kbn_visualization_ui_components.mdx
index 8f95619bd881e..4cdb4dcc48863 100644
--- a/api_docs/kbn_visualization_ui_components.mdx
+++ b/api_docs/kbn_visualization_ui_components.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-visualization-ui-components
title: "@kbn/visualization-ui-components"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/visualization-ui-components plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/visualization-ui-components']
---
import kbnVisualizationUiComponentsObj from './kbn_visualization_ui_components.devdocs.json';
diff --git a/api_docs/kbn_visualization_utils.mdx b/api_docs/kbn_visualization_utils.mdx
index ed8553f760d90..7797965497563 100644
--- a/api_docs/kbn_visualization_utils.mdx
+++ b/api_docs/kbn_visualization_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-visualization-utils
title: "@kbn/visualization-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/visualization-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/visualization-utils']
---
import kbnVisualizationUtilsObj from './kbn_visualization_utils.devdocs.json';
diff --git a/api_docs/kbn_xstate_utils.mdx b/api_docs/kbn_xstate_utils.mdx
index fbcd8f07e819e..7bfa9363cc99f 100644
--- a/api_docs/kbn_xstate_utils.mdx
+++ b/api_docs/kbn_xstate_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-xstate-utils
title: "@kbn/xstate-utils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/xstate-utils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/xstate-utils']
---
import kbnXstateUtilsObj from './kbn_xstate_utils.devdocs.json';
diff --git a/api_docs/kbn_yarn_lock_validator.mdx b/api_docs/kbn_yarn_lock_validator.mdx
index b86517d3515bc..aea98e2695c20 100644
--- a/api_docs/kbn_yarn_lock_validator.mdx
+++ b/api_docs/kbn_yarn_lock_validator.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-yarn-lock-validator
title: "@kbn/yarn-lock-validator"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/yarn-lock-validator plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/yarn-lock-validator']
---
import kbnYarnLockValidatorObj from './kbn_yarn_lock_validator.devdocs.json';
diff --git a/api_docs/kbn_zod.mdx b/api_docs/kbn_zod.mdx
index 81e64d0cc866c..407bf62f21eb3 100644
--- a/api_docs/kbn_zod.mdx
+++ b/api_docs/kbn_zod.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-zod
title: "@kbn/zod"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/zod plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/zod']
---
import kbnZodObj from './kbn_zod.devdocs.json';
diff --git a/api_docs/kbn_zod_helpers.mdx b/api_docs/kbn_zod_helpers.mdx
index a4635ed98f841..14bf0ef891707 100644
--- a/api_docs/kbn_zod_helpers.mdx
+++ b/api_docs/kbn_zod_helpers.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kbn-zod-helpers
title: "@kbn/zod-helpers"
image: https://source.unsplash.com/400x175/?github
description: API docs for the @kbn/zod-helpers plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/zod-helpers']
---
import kbnZodHelpersObj from './kbn_zod_helpers.devdocs.json';
diff --git a/api_docs/kibana_overview.mdx b/api_docs/kibana_overview.mdx
index a7b6bea089aa0..6010dc9d398a0 100644
--- a/api_docs/kibana_overview.mdx
+++ b/api_docs/kibana_overview.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kibanaOverview
title: "kibanaOverview"
image: https://source.unsplash.com/400x175/?github
description: API docs for the kibanaOverview plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kibanaOverview']
---
import kibanaOverviewObj from './kibana_overview.devdocs.json';
diff --git a/api_docs/kibana_react.mdx b/api_docs/kibana_react.mdx
index 4c30ce4671652..8a155f12d0392 100644
--- a/api_docs/kibana_react.mdx
+++ b/api_docs/kibana_react.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kibanaReact
title: "kibanaReact"
image: https://source.unsplash.com/400x175/?github
description: API docs for the kibanaReact plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kibanaReact']
---
import kibanaReactObj from './kibana_react.devdocs.json';
diff --git a/api_docs/kibana_utils.mdx b/api_docs/kibana_utils.mdx
index 20cdfab994c74..d67bcb357c42c 100644
--- a/api_docs/kibana_utils.mdx
+++ b/api_docs/kibana_utils.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kibanaUtils
title: "kibanaUtils"
image: https://source.unsplash.com/400x175/?github
description: API docs for the kibanaUtils plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kibanaUtils']
---
import kibanaUtilsObj from './kibana_utils.devdocs.json';
diff --git a/api_docs/kubernetes_security.mdx b/api_docs/kubernetes_security.mdx
index 5f32a0f03bb69..9cc9282807f58 100644
--- a/api_docs/kubernetes_security.mdx
+++ b/api_docs/kubernetes_security.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/kubernetesSecurity
title: "kubernetesSecurity"
image: https://source.unsplash.com/400x175/?github
description: API docs for the kubernetesSecurity plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kubernetesSecurity']
---
import kubernetesSecurityObj from './kubernetes_security.devdocs.json';
diff --git a/api_docs/lens.mdx b/api_docs/lens.mdx
index e19af5db11f00..d9afd39cc35d7 100644
--- a/api_docs/lens.mdx
+++ b/api_docs/lens.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/lens
title: "lens"
image: https://source.unsplash.com/400x175/?github
description: API docs for the lens plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'lens']
---
import lensObj from './lens.devdocs.json';
diff --git a/api_docs/license_api_guard.mdx b/api_docs/license_api_guard.mdx
index 4b02ebe418c1a..55a2c7e151a0a 100644
--- a/api_docs/license_api_guard.mdx
+++ b/api_docs/license_api_guard.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/licenseApiGuard
title: "licenseApiGuard"
image: https://source.unsplash.com/400x175/?github
description: API docs for the licenseApiGuard plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'licenseApiGuard']
---
import licenseApiGuardObj from './license_api_guard.devdocs.json';
diff --git a/api_docs/license_management.mdx b/api_docs/license_management.mdx
index a6077d08f0b85..55ad5949cbf6b 100644
--- a/api_docs/license_management.mdx
+++ b/api_docs/license_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/licenseManagement
title: "licenseManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the licenseManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'licenseManagement']
---
import licenseManagementObj from './license_management.devdocs.json';
diff --git a/api_docs/licensing.mdx b/api_docs/licensing.mdx
index 89474a0d91052..b9e997187a8dd 100644
--- a/api_docs/licensing.mdx
+++ b/api_docs/licensing.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/licensing
title: "licensing"
image: https://source.unsplash.com/400x175/?github
description: API docs for the licensing plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'licensing']
---
import licensingObj from './licensing.devdocs.json';
diff --git a/api_docs/links.mdx b/api_docs/links.mdx
index 4579f67afd5c2..bfa7c5c972370 100644
--- a/api_docs/links.mdx
+++ b/api_docs/links.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/links
title: "links"
image: https://source.unsplash.com/400x175/?github
description: API docs for the links plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'links']
---
import linksObj from './links.devdocs.json';
diff --git a/api_docs/lists.mdx b/api_docs/lists.mdx
index d941ddc9ae0e5..f199d4d73841a 100644
--- a/api_docs/lists.mdx
+++ b/api_docs/lists.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/lists
title: "lists"
image: https://source.unsplash.com/400x175/?github
description: API docs for the lists plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'lists']
---
import listsObj from './lists.devdocs.json';
diff --git a/api_docs/logs_data_access.mdx b/api_docs/logs_data_access.mdx
index 9b0d559f379d2..4368791d9fd22 100644
--- a/api_docs/logs_data_access.mdx
+++ b/api_docs/logs_data_access.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/logsDataAccess
title: "logsDataAccess"
image: https://source.unsplash.com/400x175/?github
description: API docs for the logsDataAccess plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'logsDataAccess']
---
import logsDataAccessObj from './logs_data_access.devdocs.json';
diff --git a/api_docs/logs_explorer.mdx b/api_docs/logs_explorer.mdx
index 6f79d85323e2a..bd25652090303 100644
--- a/api_docs/logs_explorer.mdx
+++ b/api_docs/logs_explorer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/logsExplorer
title: "logsExplorer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the logsExplorer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'logsExplorer']
---
import logsExplorerObj from './logs_explorer.devdocs.json';
diff --git a/api_docs/logs_shared.mdx b/api_docs/logs_shared.mdx
index 4dd0116eaf944..708194db1ca72 100644
--- a/api_docs/logs_shared.mdx
+++ b/api_docs/logs_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/logsShared
title: "logsShared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the logsShared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'logsShared']
---
import logsSharedObj from './logs_shared.devdocs.json';
diff --git a/api_docs/management.mdx b/api_docs/management.mdx
index ecb4521876bb1..12a4dfa78a216 100644
--- a/api_docs/management.mdx
+++ b/api_docs/management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/management
title: "management"
image: https://source.unsplash.com/400x175/?github
description: API docs for the management plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'management']
---
import managementObj from './management.devdocs.json';
diff --git a/api_docs/maps.mdx b/api_docs/maps.mdx
index 7d10614640ab7..753cc5b0e88dc 100644
--- a/api_docs/maps.mdx
+++ b/api_docs/maps.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/maps
title: "maps"
image: https://source.unsplash.com/400x175/?github
description: API docs for the maps plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'maps']
---
import mapsObj from './maps.devdocs.json';
diff --git a/api_docs/maps_ems.mdx b/api_docs/maps_ems.mdx
index 62852a7968dbb..830a2c19490ac 100644
--- a/api_docs/maps_ems.mdx
+++ b/api_docs/maps_ems.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/mapsEms
title: "mapsEms"
image: https://source.unsplash.com/400x175/?github
description: API docs for the mapsEms plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'mapsEms']
---
import mapsEmsObj from './maps_ems.devdocs.json';
diff --git a/api_docs/metrics_data_access.mdx b/api_docs/metrics_data_access.mdx
index 55d0a4df0a80e..c7df6cc036db2 100644
--- a/api_docs/metrics_data_access.mdx
+++ b/api_docs/metrics_data_access.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/metricsDataAccess
title: "metricsDataAccess"
image: https://source.unsplash.com/400x175/?github
description: API docs for the metricsDataAccess plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'metricsDataAccess']
---
import metricsDataAccessObj from './metrics_data_access.devdocs.json';
diff --git a/api_docs/ml.mdx b/api_docs/ml.mdx
index bc66921e8536c..952102823a86d 100644
--- a/api_docs/ml.mdx
+++ b/api_docs/ml.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/ml
title: "ml"
image: https://source.unsplash.com/400x175/?github
description: API docs for the ml plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ml']
---
import mlObj from './ml.devdocs.json';
diff --git a/api_docs/mock_idp_plugin.mdx b/api_docs/mock_idp_plugin.mdx
index ff7b1a876ade5..43e9681c9472c 100644
--- a/api_docs/mock_idp_plugin.mdx
+++ b/api_docs/mock_idp_plugin.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/mockIdpPlugin
title: "mockIdpPlugin"
image: https://source.unsplash.com/400x175/?github
description: API docs for the mockIdpPlugin plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'mockIdpPlugin']
---
import mockIdpPluginObj from './mock_idp_plugin.devdocs.json';
diff --git a/api_docs/monitoring.mdx b/api_docs/monitoring.mdx
index 0a77f516d7c6a..bd52b69d93172 100644
--- a/api_docs/monitoring.mdx
+++ b/api_docs/monitoring.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/monitoring
title: "monitoring"
image: https://source.unsplash.com/400x175/?github
description: API docs for the monitoring plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'monitoring']
---
import monitoringObj from './monitoring.devdocs.json';
diff --git a/api_docs/monitoring_collection.mdx b/api_docs/monitoring_collection.mdx
index 17623a051c230..a5fa365dac656 100644
--- a/api_docs/monitoring_collection.mdx
+++ b/api_docs/monitoring_collection.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/monitoringCollection
title: "monitoringCollection"
image: https://source.unsplash.com/400x175/?github
description: API docs for the monitoringCollection plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'monitoringCollection']
---
import monitoringCollectionObj from './monitoring_collection.devdocs.json';
diff --git a/api_docs/navigation.mdx b/api_docs/navigation.mdx
index c8479b8f6c3bd..87c865d4bcc22 100644
--- a/api_docs/navigation.mdx
+++ b/api_docs/navigation.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/navigation
title: "navigation"
image: https://source.unsplash.com/400x175/?github
description: API docs for the navigation plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'navigation']
---
import navigationObj from './navigation.devdocs.json';
diff --git a/api_docs/newsfeed.mdx b/api_docs/newsfeed.mdx
index 4626648b0173a..30e0d47d55770 100644
--- a/api_docs/newsfeed.mdx
+++ b/api_docs/newsfeed.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/newsfeed
title: "newsfeed"
image: https://source.unsplash.com/400x175/?github
description: API docs for the newsfeed plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'newsfeed']
---
import newsfeedObj from './newsfeed.devdocs.json';
diff --git a/api_docs/no_data_page.mdx b/api_docs/no_data_page.mdx
index e3b099d7d3855..1d5d98c9f5b11 100644
--- a/api_docs/no_data_page.mdx
+++ b/api_docs/no_data_page.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/noDataPage
title: "noDataPage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the noDataPage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'noDataPage']
---
import noDataPageObj from './no_data_page.devdocs.json';
diff --git a/api_docs/notifications.mdx b/api_docs/notifications.mdx
index af3063506a47d..db2df8ad452b6 100644
--- a/api_docs/notifications.mdx
+++ b/api_docs/notifications.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/notifications
title: "notifications"
image: https://source.unsplash.com/400x175/?github
description: API docs for the notifications plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'notifications']
---
import notificationsObj from './notifications.devdocs.json';
diff --git a/api_docs/observability.mdx b/api_docs/observability.mdx
index f11e525ac5827..5abbbd33852ee 100644
--- a/api_docs/observability.mdx
+++ b/api_docs/observability.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observability
title: "observability"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observability plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observability']
---
import observabilityObj from './observability.devdocs.json';
diff --git a/api_docs/observability_a_i_assistant.mdx b/api_docs/observability_a_i_assistant.mdx
index c85e717e3e681..cc426946e39fd 100644
--- a/api_docs/observability_a_i_assistant.mdx
+++ b/api_docs/observability_a_i_assistant.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observabilityAIAssistant
title: "observabilityAIAssistant"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observabilityAIAssistant plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observabilityAIAssistant']
---
import observabilityAIAssistantObj from './observability_a_i_assistant.devdocs.json';
diff --git a/api_docs/observability_a_i_assistant_app.mdx b/api_docs/observability_a_i_assistant_app.mdx
index 273fad4c959f6..625f342af0ecf 100644
--- a/api_docs/observability_a_i_assistant_app.mdx
+++ b/api_docs/observability_a_i_assistant_app.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observabilityAIAssistantApp
title: "observabilityAIAssistantApp"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observabilityAIAssistantApp plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observabilityAIAssistantApp']
---
import observabilityAIAssistantAppObj from './observability_a_i_assistant_app.devdocs.json';
diff --git a/api_docs/observability_ai_assistant_management.mdx b/api_docs/observability_ai_assistant_management.mdx
index 4d561aa24aea0..ed97f6b915448 100644
--- a/api_docs/observability_ai_assistant_management.mdx
+++ b/api_docs/observability_ai_assistant_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observabilityAiAssistantManagement
title: "observabilityAiAssistantManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observabilityAiAssistantManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observabilityAiAssistantManagement']
---
import observabilityAiAssistantManagementObj from './observability_ai_assistant_management.devdocs.json';
diff --git a/api_docs/observability_logs_explorer.mdx b/api_docs/observability_logs_explorer.mdx
index 8ff21a34d6a4e..4a19dd9d48be9 100644
--- a/api_docs/observability_logs_explorer.mdx
+++ b/api_docs/observability_logs_explorer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observabilityLogsExplorer
title: "observabilityLogsExplorer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observabilityLogsExplorer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observabilityLogsExplorer']
---
import observabilityLogsExplorerObj from './observability_logs_explorer.devdocs.json';
diff --git a/api_docs/observability_onboarding.mdx b/api_docs/observability_onboarding.mdx
index 359ae8a35159a..2851d4e75a0bc 100644
--- a/api_docs/observability_onboarding.mdx
+++ b/api_docs/observability_onboarding.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observabilityOnboarding
title: "observabilityOnboarding"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observabilityOnboarding plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observabilityOnboarding']
---
import observabilityOnboardingObj from './observability_onboarding.devdocs.json';
diff --git a/api_docs/observability_shared.mdx b/api_docs/observability_shared.mdx
index bb6c225bc54d5..127911cbf86cf 100644
--- a/api_docs/observability_shared.mdx
+++ b/api_docs/observability_shared.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/observabilityShared
title: "observabilityShared"
image: https://source.unsplash.com/400x175/?github
description: API docs for the observabilityShared plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observabilityShared']
---
import observabilitySharedObj from './observability_shared.devdocs.json';
diff --git a/api_docs/osquery.mdx b/api_docs/osquery.mdx
index 00b15d6aaef9a..e45d68e6d7ce2 100644
--- a/api_docs/osquery.mdx
+++ b/api_docs/osquery.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/osquery
title: "osquery"
image: https://source.unsplash.com/400x175/?github
description: API docs for the osquery plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'osquery']
---
import osqueryObj from './osquery.devdocs.json';
diff --git a/api_docs/painless_lab.mdx b/api_docs/painless_lab.mdx
index c138364e4dacc..ca6f97230e12c 100644
--- a/api_docs/painless_lab.mdx
+++ b/api_docs/painless_lab.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/painlessLab
title: "painlessLab"
image: https://source.unsplash.com/400x175/?github
description: API docs for the painlessLab plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'painlessLab']
---
import painlessLabObj from './painless_lab.devdocs.json';
diff --git a/api_docs/plugin_directory.mdx b/api_docs/plugin_directory.mdx
index 26136b8e454ff..0873bb827ba5b 100644
--- a/api_docs/plugin_directory.mdx
+++ b/api_docs/plugin_directory.mdx
@@ -7,7 +7,7 @@ id: kibDevDocsPluginDirectory
slug: /kibana-dev-docs/api-meta/plugin-api-directory
title: Directory
description: Directory of public APIs available through plugins or packages.
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana']
---
@@ -21,7 +21,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| API Count | Any Count | Missing comments | Missing exports |
|--------------|----------|-----------------|--------|
-| 54127 | 242 | 40683 | 2018 |
+| 54098 | 242 | 40653 | 2018 |
## Plugin Directory
@@ -39,7 +39,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| | [@elastic/kibana-presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds Canvas application to Kibana | 9 | 0 | 8 | 3 |
| | [@elastic/response-ops](https://github.com/orgs/elastic/teams/response-ops) | The Case management system in Kibana | 115 | 0 | 95 | 28 |
| | [@elastic/kibana-visualizations](https://github.com/orgs/elastic/teams/kibana-visualizations) | - | 268 | 2 | 253 | 10 |
-| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 84 | 0 | 21 | 1 |
+| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 83 | 0 | 20 | 1 |
| cloudChat | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | Chat available on Elastic Cloud deployments for quicker assistance. | 0 | 0 | 0 | 0 |
| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | Static migration page where self-managed users can see text/copy about migrating to Elastic Cloud | 8 | 0 | 8 | 1 |
| | [@elastic/kibana-cloud-security-posture](https://github.com/orgs/elastic/teams/kibana-cloud-security-posture) | Defend for containers (D4C) | 52 | 0 | 43 | 2 |
@@ -114,7 +114,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 149 | 0 | 111 | 1 |
| | [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sharedux) | Image embeddable | 1 | 0 | 1 | 0 |
| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 4 | 0 | 4 | 0 |
-| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 250 | 0 | 245 | 1 |
+| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 241 | 0 | 236 | 1 |
| | [@elastic/appex-ai-infra](https://github.com/orgs/elastic/teams/appex-ai-infra) | - | 49 | 0 | 44 | 15 |
| | [@elastic/obs-ux-logs-team](https://github.com/orgs/elastic/teams/obs-ux-logs-team) | This plugin visualizes data from Filebeat and Metricbeat, and integrates with other Observability solutions | 24 | 0 | 24 | 5 |
| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 4 | 0 | 4 | 0 |
@@ -168,7 +168,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 23 | 0 | 23 | 0 |
| | [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sharedux) | Reporting Services enables applications to feature reports that the user can automate with Watcher and download later. | 9 | 0 | 2 | 0 |
| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 21 | 0 | 21 | 0 |
-| | [@elastic/response-ops](https://github.com/orgs/elastic/teams/response-ops) | - | 285 | 0 | 248 | 11 |
+| | [@elastic/response-ops](https://github.com/orgs/elastic/teams/response-ops) | - | 263 | 0 | 226 | 10 |
| | [@elastic/kibana-management](https://github.com/orgs/elastic/teams/kibana-management) | - | 24 | 0 | 19 | 2 |
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 114 | 2 | 109 | 5 |
| | [@elastic/kibana-data-discovery](https://github.com/orgs/elastic/teams/kibana-data-discovery) | - | 25 | 0 | 25 | 0 |
@@ -243,7 +243,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| Package name | Maintaining team | Description | API Cnt | Any Cnt | Missing
comments | Missing
exports |
|--------------|----------------|-----------|--------------|----------|---------------|--------|
| | [@elastic/response-ops](https://github.com/orgs/elastic/teams/response-ops) | - | 14 | 0 | 14 | 0 |
-| | [@elastic/search-kibana](https://github.com/orgs/elastic/teams/search-kibana) | - | 63 | 0 | 63 | 1 |
+| | [@elastic/search-kibana](https://github.com/orgs/elastic/teams/search-kibana) | - | 64 | 0 | 64 | 1 |
| | [@elastic/search-kibana](https://github.com/orgs/elastic/teams/search-kibana) | - | 3 | 0 | 3 | 0 |
| | [@elastic/ml-ui](https://github.com/orgs/elastic/teams/ml-ui) | - | 36 | 0 | 0 | 0 |
| | [@elastic/ml-ui](https://github.com/orgs/elastic/teams/ml-ui) | - | 2 | 0 | 0 | 0 |
@@ -319,7 +319,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 5 | 0 | 0 | 0 |
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 20 | 0 | 7 | 0 |
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 6 | 0 | 6 | 0 |
-| | [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sharedux) | - | 210 | 0 | 103 | 0 |
+| | [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sharedux) | - | 211 | 0 | 104 | 0 |
| | [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sharedux) | - | 3 | 0 | 3 | 0 |
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 6 | 0 | 1 | 0 |
| | [@elastic/appex-sharedux](https://github.com/orgs/elastic/teams/appex-sharedux) | - | 8 | 0 | 8 | 0 |
@@ -520,7 +520,7 @@ tags: ['contributor', 'dev', 'apidocs', 'kibana']
| | [@elastic/kibana-data-discovery](https://github.com/orgs/elastic/teams/kibana-data-discovery) | - | 271 | 1 | 210 | 14 |
| | [@elastic/kibana-core](https://github.com/orgs/elastic/teams/kibana-core) | - | 29 | 0 | 29 | 1 |
| | [@elastic/kibana-operations](https://github.com/orgs/elastic/teams/kibana-operations) | - | 2 | 0 | 1 | 0 |
-| | [@elastic/kibana-esql](https://github.com/orgs/elastic/teams/kibana-esql) | - | 269 | 1 | 211 | 34 |
+| | [@elastic/kibana-esql](https://github.com/orgs/elastic/teams/kibana-esql) | - | 270 | 1 | 211 | 35 |
| | [@elastic/kibana-esql](https://github.com/orgs/elastic/teams/kibana-esql) | - | 29 | 0 | 12 | 0 |
| | [@elastic/kibana-esql](https://github.com/orgs/elastic/teams/kibana-esql) | - | 79 | 0 | 71 | 0 |
| | [@elastic/kibana-esql](https://github.com/orgs/elastic/teams/kibana-esql) | - | 202 | 0 | 190 | 12 |
diff --git a/api_docs/presentation_panel.mdx b/api_docs/presentation_panel.mdx
index 871f964c0b290..16b10e77fb4cc 100644
--- a/api_docs/presentation_panel.mdx
+++ b/api_docs/presentation_panel.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/presentationPanel
title: "presentationPanel"
image: https://source.unsplash.com/400x175/?github
description: API docs for the presentationPanel plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'presentationPanel']
---
import presentationPanelObj from './presentation_panel.devdocs.json';
diff --git a/api_docs/presentation_util.mdx b/api_docs/presentation_util.mdx
index 0e0b60fe77f35..ab8af618daa21 100644
--- a/api_docs/presentation_util.mdx
+++ b/api_docs/presentation_util.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/presentationUtil
title: "presentationUtil"
image: https://source.unsplash.com/400x175/?github
description: API docs for the presentationUtil plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'presentationUtil']
---
import presentationUtilObj from './presentation_util.devdocs.json';
diff --git a/api_docs/profiling.mdx b/api_docs/profiling.mdx
index b17a03cab0d58..3927cb35d6f28 100644
--- a/api_docs/profiling.mdx
+++ b/api_docs/profiling.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/profiling
title: "profiling"
image: https://source.unsplash.com/400x175/?github
description: API docs for the profiling plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'profiling']
---
import profilingObj from './profiling.devdocs.json';
diff --git a/api_docs/profiling_data_access.mdx b/api_docs/profiling_data_access.mdx
index d2b0121ad506d..5729edd18fa41 100644
--- a/api_docs/profiling_data_access.mdx
+++ b/api_docs/profiling_data_access.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/profilingDataAccess
title: "profilingDataAccess"
image: https://source.unsplash.com/400x175/?github
description: API docs for the profilingDataAccess plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'profilingDataAccess']
---
import profilingDataAccessObj from './profiling_data_access.devdocs.json';
diff --git a/api_docs/remote_clusters.mdx b/api_docs/remote_clusters.mdx
index db95d43cd4a23..f34d7a56edb57 100644
--- a/api_docs/remote_clusters.mdx
+++ b/api_docs/remote_clusters.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/remoteClusters
title: "remoteClusters"
image: https://source.unsplash.com/400x175/?github
description: API docs for the remoteClusters plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'remoteClusters']
---
import remoteClustersObj from './remote_clusters.devdocs.json';
diff --git a/api_docs/reporting.mdx b/api_docs/reporting.mdx
index 30fffbf0f152b..b999656ed4763 100644
--- a/api_docs/reporting.mdx
+++ b/api_docs/reporting.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/reporting
title: "reporting"
image: https://source.unsplash.com/400x175/?github
description: API docs for the reporting plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'reporting']
---
import reportingObj from './reporting.devdocs.json';
diff --git a/api_docs/rollup.mdx b/api_docs/rollup.mdx
index df363377b0cf1..47570ddea95fb 100644
--- a/api_docs/rollup.mdx
+++ b/api_docs/rollup.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/rollup
title: "rollup"
image: https://source.unsplash.com/400x175/?github
description: API docs for the rollup plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'rollup']
---
import rollupObj from './rollup.devdocs.json';
diff --git a/api_docs/rule_registry.devdocs.json b/api_docs/rule_registry.devdocs.json
index d12d867f04393..17ebe064cea2a 100644
--- a/api_docs/rule_registry.devdocs.json
+++ b/api_docs/rule_registry.devdocs.json
@@ -1879,266 +1879,6 @@
"returnComment": [],
"initialIsOpen": false
},
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleExecutor",
- "type": "Function",
- "tags": [],
- "label": "createLifecycleExecutor",
- "description": [],
- "signature": [
- "(logger: ",
- {
- "pluginId": "@kbn/logging",
- "scope": "common",
- "docId": "kibKbnLoggingPluginApi",
- "section": "def-common.Logger",
- "text": "Logger"
- },
- ", ruleDataClient: ",
- {
- "pluginId": "@kbn/utility-types",
- "scope": "common",
- "docId": "kibKbnUtilityTypesPluginApi",
- "section": "def-common.PublicContract",
- "text": "PublicContract"
- },
- "<",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.IRuleDataClient",
- "text": "IRuleDataClient"
- },
- ">) => = never, InstanceContext extends { [x: string]: unknown; } = never, ActionGroupIds extends string = never>(wrappedExecutor: ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.LifecycleRuleExecutor",
- "text": "LifecycleRuleExecutor"
- },
- ") => (options: ",
- {
- "pluginId": "alerting",
- "scope": "server",
- "docId": "kibAlertingPluginApi",
- "section": "def-server.RuleExecutorOptions",
- "text": "RuleExecutorOptions"
- },
- ", InstanceState, InstanceContext, ActionGroupIds, never>) => Promise<{ state: ",
- {
- "pluginId": "@kbn/alerting-state-types",
- "scope": "server",
- "docId": "kibKbnAlertingStateTypesPluginApi",
- "section": "def-server.WrappedLifecycleRuleState",
- "text": "WrappedLifecycleRuleState"
- },
- "; }>"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleExecutor.$1",
- "type": "Object",
- "tags": [],
- "label": "logger",
- "description": [],
- "signature": [
- {
- "pluginId": "@kbn/logging",
- "scope": "common",
- "docId": "kibKbnLoggingPluginApi",
- "section": "def-common.Logger",
- "text": "Logger"
- }
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "isRequired": true
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleExecutor.$2",
- "type": "Object",
- "tags": [],
- "label": "ruleDataClient",
- "description": [],
- "signature": [
- {
- "pluginId": "@kbn/utility-types",
- "scope": "common",
- "docId": "kibKbnUtilityTypesPluginApi",
- "section": "def-common.PublicContract",
- "text": "PublicContract"
- },
- "<",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.IRuleDataClient",
- "text": "IRuleDataClient"
- },
- ">"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "isRequired": true
- }
- ],
- "returnComment": [],
- "initialIsOpen": false
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleRuleTypeFactory",
- "type": "Function",
- "tags": [],
- "label": "createLifecycleRuleTypeFactory",
- "description": [],
- "signature": [
- "({ logger, ruleDataClient }: { logger: ",
- {
- "pluginId": "@kbn/logging",
- "scope": "common",
- "docId": "kibKbnLoggingPluginApi",
- "section": "def-common.Logger",
- "text": "Logger"
- },
- "; ruleDataClient: ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.IRuleDataClient",
- "text": "IRuleDataClient"
- },
- "; }) => , TAlertInstanceContext extends { [x: string]: unknown; }, TActionGroupIds extends string, TServices extends ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.LifecycleAlertServices",
- "text": "LifecycleAlertServices"
- },
- ">(type: ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.AlertTypeWithExecutor",
- "text": "AlertTypeWithExecutor"
- },
- ") => ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.AlertTypeWithExecutor",
- "text": "AlertTypeWithExecutor"
- },
- ""
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleRuleTypeFactory.$1",
- "type": "Object",
- "tags": [],
- "label": "{ logger, ruleDataClient }",
- "description": [],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleRuleTypeFactory.$1.logger",
- "type": "Object",
- "tags": [],
- "label": "logger",
- "description": [],
- "signature": [
- {
- "pluginId": "@kbn/logging",
- "scope": "common",
- "docId": "kibKbnLoggingPluginApi",
- "section": "def-common.Logger",
- "text": "Logger"
- }
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts",
- "deprecated": false,
- "trackAdoption": false
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.createLifecycleRuleTypeFactory.$1.ruleDataClient",
- "type": "Object",
- "tags": [],
- "label": "ruleDataClient",
- "description": [],
- "signature": [
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.IRuleDataClient",
- "text": "IRuleDataClient"
- }
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ]
- }
- ],
- "returnComment": [],
- "initialIsOpen": false
- },
{
"parentPluginId": "ruleRegistry",
"id": "def-server.createPersistenceRuleTypeWrapper",
@@ -3414,173 +3154,6 @@
],
"initialIsOpen": false
},
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices",
- "type": "Interface",
- "tags": [],
- "label": "LifecycleAlertServices",
- "description": [],
- "signature": [
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.LifecycleAlertServices",
- "text": "LifecycleAlertServices"
- },
- ""
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.alertWithLifecycle",
- "type": "Function",
- "tags": [],
- "label": "alertWithLifecycle",
- "description": [],
- "signature": [
- "(alert: { id: string; fields: ExplicitAlertFields; }) => ",
- {
- "pluginId": "alerting",
- "scope": "server",
- "docId": "kibAlertingPluginApi",
- "section": "def-server.PublicAlert",
- "text": "PublicAlert"
- },
- ""
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "returnComment": [],
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.alertWithLifecycle.$1",
- "type": "Object",
- "tags": [],
- "label": "alert",
- "description": [],
- "signature": [
- "{ id: string; fields: ExplicitAlertFields; }"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ]
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.getAlertStartedDate",
- "type": "Function",
- "tags": [],
- "label": "getAlertStartedDate",
- "description": [],
- "signature": [
- "(alertInstanceId: string) => string | null"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.getAlertStartedDate.$1",
- "type": "string",
- "tags": [],
- "label": "alertInstanceId",
- "description": [],
- "signature": [
- "string"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "isRequired": true
- }
- ],
- "returnComment": []
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.getAlertUuid",
- "type": "Function",
- "tags": [],
- "label": "getAlertUuid",
- "description": [],
- "signature": [
- "(alertInstanceId: string) => string"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.getAlertUuid.$1",
- "type": "string",
- "tags": [],
- "label": "alertInstanceId",
- "description": [],
- "signature": [
- "string"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "isRequired": true
- }
- ],
- "returnComment": []
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.getAlertByAlertUuid",
- "type": "Function",
- "tags": [],
- "label": "getAlertByAlertUuid",
- "description": [],
- "signature": [
- "(alertUuid: string) => Promise> & OutputOf>> | null> | null"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertServices.getAlertByAlertUuid.$1",
- "type": "string",
- "tags": [],
- "label": "alertUuid",
- "description": [],
- "signature": [
- "string"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "isRequired": true
- }
- ],
- "returnComment": []
- }
- ],
- "initialIsOpen": false
- },
{
"parentPluginId": "ruleRegistry",
"id": "def-server.PersistenceAlertServiceResult",
@@ -4265,120 +3838,6 @@
"trackAdoption": false,
"initialIsOpen": false
},
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertService",
- "type": "Type",
- "tags": [],
- "label": "LifecycleAlertService",
- "description": [],
- "signature": [
- "(alert: { id: string; fields: ExplicitAlertFields; }) => ",
- {
- "pluginId": "alerting",
- "scope": "server",
- "docId": "kibAlertingPluginApi",
- "section": "def-server.PublicAlert",
- "text": "PublicAlert"
- },
- ""
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "returnComment": [],
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleAlertService.$1",
- "type": "Object",
- "tags": [],
- "label": "alert",
- "description": [],
- "signature": [
- "{ id: string; fields: ExplicitAlertFields; }"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ],
- "initialIsOpen": false
- },
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleRuleExecutor",
- "type": "Type",
- "tags": [],
- "label": "LifecycleRuleExecutor",
- "description": [],
- "signature": [
- "(options: ",
- "AlertExecutorOptionsWithExtraServices",
- ">) => Promise<{ state: State; }>"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false,
- "returnComment": [],
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.LifecycleRuleExecutor.$1",
- "type": "CompoundType",
- "tags": [],
- "label": "options",
- "description": [],
- "signature": [
- "Omit<",
- {
- "pluginId": "alerting",
- "scope": "server",
- "docId": "kibAlertingPluginApi",
- "section": "def-server.RuleExecutorOptions",
- "text": "RuleExecutorOptions"
- },
- ", \"services\"> & { services: ",
- {
- "pluginId": "alerting",
- "scope": "server",
- "docId": "kibAlertingPluginApi",
- "section": "def-server.RuleExecutorServices",
- "text": "RuleExecutorServices"
- },
- " & ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.LifecycleAlertServices",
- "text": "LifecycleAlertServices"
- },
- "; }"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ],
- "initialIsOpen": false
- },
{
"parentPluginId": "ruleRegistry",
"id": "def-server.Mappings",
@@ -4848,101 +4307,6 @@
"deprecated": false,
"trackAdoption": false
},
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.RuleRegistryPluginSetupContract.createLifecycleRuleTypeFactory",
- "type": "Function",
- "tags": [],
- "label": "createLifecycleRuleTypeFactory",
- "description": [],
- "signature": [
- "({ logger, ruleDataClient }: { logger: ",
- {
- "pluginId": "@kbn/logging",
- "scope": "common",
- "docId": "kibKbnLoggingPluginApi",
- "section": "def-common.Logger",
- "text": "Logger"
- },
- "; ruleDataClient: ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.IRuleDataClient",
- "text": "IRuleDataClient"
- },
- "; }) => , TAlertInstanceContext extends { [x: string]: unknown; }, TActionGroupIds extends string, TServices extends ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.LifecycleAlertServices",
- "text": "LifecycleAlertServices"
- },
- ">(type: ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.AlertTypeWithExecutor",
- "text": "AlertTypeWithExecutor"
- },
- ") => ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.AlertTypeWithExecutor",
- "text": "AlertTypeWithExecutor"
- },
- ""
- ],
- "path": "x-pack/plugins/rule_registry/server/plugin.ts",
- "deprecated": false,
- "trackAdoption": false,
- "returnComment": [],
- "children": [
- {
- "parentPluginId": "ruleRegistry",
- "id": "def-server.RuleRegistryPluginSetupContract.createLifecycleRuleTypeFactory.$1",
- "type": "Object",
- "tags": [],
- "label": "__0",
- "description": [],
- "signature": [
- "{ logger: ",
- {
- "pluginId": "@kbn/logging",
- "scope": "common",
- "docId": "kibKbnLoggingPluginApi",
- "section": "def-common.Logger",
- "text": "Logger"
- },
- "; ruleDataClient: ",
- {
- "pluginId": "ruleRegistry",
- "scope": "server",
- "docId": "kibRuleRegistryPluginApi",
- "section": "def-server.IRuleDataClient",
- "text": "IRuleDataClient"
- },
- "; }"
- ],
- "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts",
- "deprecated": false,
- "trackAdoption": false
- }
- ]
- },
{
"parentPluginId": "ruleRegistry",
"id": "def-server.RuleRegistryPluginSetupContract.dataset",
diff --git a/api_docs/rule_registry.mdx b/api_docs/rule_registry.mdx
index 9a00a527769fc..b3b59ac359137 100644
--- a/api_docs/rule_registry.mdx
+++ b/api_docs/rule_registry.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/ruleRegistry
title: "ruleRegistry"
image: https://source.unsplash.com/400x175/?github
description: API docs for the ruleRegistry plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ruleRegistry']
---
import ruleRegistryObj from './rule_registry.devdocs.json';
@@ -21,7 +21,7 @@ Contact [@elastic/response-ops](https://github.com/orgs/elastic/teams/response-o
| Public API count | Any count | Items lacking comments | Missing exports |
|-------------------|-----------|------------------------|-----------------|
-| 285 | 0 | 248 | 11 |
+| 263 | 0 | 226 | 10 |
## Server
diff --git a/api_docs/runtime_fields.mdx b/api_docs/runtime_fields.mdx
index a41ac94730f77..4213d49a47d64 100644
--- a/api_docs/runtime_fields.mdx
+++ b/api_docs/runtime_fields.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/runtimeFields
title: "runtimeFields"
image: https://source.unsplash.com/400x175/?github
description: API docs for the runtimeFields plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'runtimeFields']
---
import runtimeFieldsObj from './runtime_fields.devdocs.json';
diff --git a/api_docs/saved_objects.mdx b/api_docs/saved_objects.mdx
index 1deef6755f656..de70b1f69fdd0 100644
--- a/api_docs/saved_objects.mdx
+++ b/api_docs/saved_objects.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/savedObjects
title: "savedObjects"
image: https://source.unsplash.com/400x175/?github
description: API docs for the savedObjects plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjects']
---
import savedObjectsObj from './saved_objects.devdocs.json';
diff --git a/api_docs/saved_objects_finder.mdx b/api_docs/saved_objects_finder.mdx
index d8f0ecee283ea..32565bccf0842 100644
--- a/api_docs/saved_objects_finder.mdx
+++ b/api_docs/saved_objects_finder.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/savedObjectsFinder
title: "savedObjectsFinder"
image: https://source.unsplash.com/400x175/?github
description: API docs for the savedObjectsFinder plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsFinder']
---
import savedObjectsFinderObj from './saved_objects_finder.devdocs.json';
diff --git a/api_docs/saved_objects_management.mdx b/api_docs/saved_objects_management.mdx
index fc5960c4caf9c..311f1fc210a9f 100644
--- a/api_docs/saved_objects_management.mdx
+++ b/api_docs/saved_objects_management.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/savedObjectsManagement
title: "savedObjectsManagement"
image: https://source.unsplash.com/400x175/?github
description: API docs for the savedObjectsManagement plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsManagement']
---
import savedObjectsManagementObj from './saved_objects_management.devdocs.json';
diff --git a/api_docs/saved_objects_tagging.mdx b/api_docs/saved_objects_tagging.mdx
index 80245ddae64c2..c5da7879f7c2d 100644
--- a/api_docs/saved_objects_tagging.mdx
+++ b/api_docs/saved_objects_tagging.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/savedObjectsTagging
title: "savedObjectsTagging"
image: https://source.unsplash.com/400x175/?github
description: API docs for the savedObjectsTagging plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsTagging']
---
import savedObjectsTaggingObj from './saved_objects_tagging.devdocs.json';
diff --git a/api_docs/saved_objects_tagging_oss.mdx b/api_docs/saved_objects_tagging_oss.mdx
index 7e6486f03aff2..6ac50d30fefa2 100644
--- a/api_docs/saved_objects_tagging_oss.mdx
+++ b/api_docs/saved_objects_tagging_oss.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/savedObjectsTaggingOss
title: "savedObjectsTaggingOss"
image: https://source.unsplash.com/400x175/?github
description: API docs for the savedObjectsTaggingOss plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsTaggingOss']
---
import savedObjectsTaggingOssObj from './saved_objects_tagging_oss.devdocs.json';
diff --git a/api_docs/saved_search.mdx b/api_docs/saved_search.mdx
index edd6c38aff9fb..0823713fa2f7a 100644
--- a/api_docs/saved_search.mdx
+++ b/api_docs/saved_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/savedSearch
title: "savedSearch"
image: https://source.unsplash.com/400x175/?github
description: API docs for the savedSearch plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedSearch']
---
import savedSearchObj from './saved_search.devdocs.json';
diff --git a/api_docs/screenshot_mode.mdx b/api_docs/screenshot_mode.mdx
index 2dc5648f46e6c..c79272bcab541 100644
--- a/api_docs/screenshot_mode.mdx
+++ b/api_docs/screenshot_mode.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/screenshotMode
title: "screenshotMode"
image: https://source.unsplash.com/400x175/?github
description: API docs for the screenshotMode plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'screenshotMode']
---
import screenshotModeObj from './screenshot_mode.devdocs.json';
diff --git a/api_docs/screenshotting.mdx b/api_docs/screenshotting.mdx
index 87eba25337fb6..c189de373b251 100644
--- a/api_docs/screenshotting.mdx
+++ b/api_docs/screenshotting.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/screenshotting
title: "screenshotting"
image: https://source.unsplash.com/400x175/?github
description: API docs for the screenshotting plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'screenshotting']
---
import screenshottingObj from './screenshotting.devdocs.json';
diff --git a/api_docs/search_assistant.mdx b/api_docs/search_assistant.mdx
index a7828dfbdfab3..09f5e8dbd2f98 100644
--- a/api_docs/search_assistant.mdx
+++ b/api_docs/search_assistant.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchAssistant
title: "searchAssistant"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchAssistant plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchAssistant']
---
import searchAssistantObj from './search_assistant.devdocs.json';
diff --git a/api_docs/search_connectors.mdx b/api_docs/search_connectors.mdx
index 8e2304fadb23b..e9b0559250df3 100644
--- a/api_docs/search_connectors.mdx
+++ b/api_docs/search_connectors.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchConnectors
title: "searchConnectors"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchConnectors plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchConnectors']
---
import searchConnectorsObj from './search_connectors.devdocs.json';
diff --git a/api_docs/search_homepage.mdx b/api_docs/search_homepage.mdx
index 6e650a3edafad..ab6fb76c6ecf5 100644
--- a/api_docs/search_homepage.mdx
+++ b/api_docs/search_homepage.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchHomepage
title: "searchHomepage"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchHomepage plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchHomepage']
---
import searchHomepageObj from './search_homepage.devdocs.json';
diff --git a/api_docs/search_indices.mdx b/api_docs/search_indices.mdx
index b347d8fd79d60..6c22ef39e3d9a 100644
--- a/api_docs/search_indices.mdx
+++ b/api_docs/search_indices.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchIndices
title: "searchIndices"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchIndices plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchIndices']
---
import searchIndicesObj from './search_indices.devdocs.json';
diff --git a/api_docs/search_inference_endpoints.mdx b/api_docs/search_inference_endpoints.mdx
index 6caba874caa57..ace1269008f04 100644
--- a/api_docs/search_inference_endpoints.mdx
+++ b/api_docs/search_inference_endpoints.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchInferenceEndpoints
title: "searchInferenceEndpoints"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchInferenceEndpoints plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchInferenceEndpoints']
---
import searchInferenceEndpointsObj from './search_inference_endpoints.devdocs.json';
diff --git a/api_docs/search_notebooks.mdx b/api_docs/search_notebooks.mdx
index fe3b5041a92b5..58f43079c034e 100644
--- a/api_docs/search_notebooks.mdx
+++ b/api_docs/search_notebooks.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchNotebooks
title: "searchNotebooks"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchNotebooks plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchNotebooks']
---
import searchNotebooksObj from './search_notebooks.devdocs.json';
diff --git a/api_docs/search_playground.mdx b/api_docs/search_playground.mdx
index 9d3ad8c0fa820..4be8fad3aa7e0 100644
--- a/api_docs/search_playground.mdx
+++ b/api_docs/search_playground.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/searchPlayground
title: "searchPlayground"
image: https://source.unsplash.com/400x175/?github
description: API docs for the searchPlayground plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'searchPlayground']
---
import searchPlaygroundObj from './search_playground.devdocs.json';
diff --git a/api_docs/security.mdx b/api_docs/security.mdx
index 188be47c684f8..2f3eec79dadc9 100644
--- a/api_docs/security.mdx
+++ b/api_docs/security.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/security
title: "security"
image: https://source.unsplash.com/400x175/?github
description: API docs for the security plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'security']
---
import securityObj from './security.devdocs.json';
diff --git a/api_docs/security_solution.mdx b/api_docs/security_solution.mdx
index 7cd4d7de069c9..586390523a44d 100644
--- a/api_docs/security_solution.mdx
+++ b/api_docs/security_solution.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/securitySolution
title: "securitySolution"
image: https://source.unsplash.com/400x175/?github
description: API docs for the securitySolution plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'securitySolution']
---
import securitySolutionObj from './security_solution.devdocs.json';
diff --git a/api_docs/security_solution_ess.mdx b/api_docs/security_solution_ess.mdx
index 316f99781fd50..d009bb108a27b 100644
--- a/api_docs/security_solution_ess.mdx
+++ b/api_docs/security_solution_ess.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/securitySolutionEss
title: "securitySolutionEss"
image: https://source.unsplash.com/400x175/?github
description: API docs for the securitySolutionEss plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'securitySolutionEss']
---
import securitySolutionEssObj from './security_solution_ess.devdocs.json';
diff --git a/api_docs/security_solution_serverless.mdx b/api_docs/security_solution_serverless.mdx
index 812ea95efbfda..e39fcaaa9f7d9 100644
--- a/api_docs/security_solution_serverless.mdx
+++ b/api_docs/security_solution_serverless.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/securitySolutionServerless
title: "securitySolutionServerless"
image: https://source.unsplash.com/400x175/?github
description: API docs for the securitySolutionServerless plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'securitySolutionServerless']
---
import securitySolutionServerlessObj from './security_solution_serverless.devdocs.json';
diff --git a/api_docs/serverless.devdocs.json b/api_docs/serverless.devdocs.json
index 110cf72e9d79e..5ff67d3104e84 100644
--- a/api_docs/serverless.devdocs.json
+++ b/api_docs/serverless.devdocs.json
@@ -166,7 +166,15 @@
"label": "initNavigation",
"description": [],
"signature": [
- "(id: string, navigationTree$: ",
+ "(id: ",
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionId",
+ "text": "SolutionId"
+ },
+ ", navigationTree$: ",
"Observable",
"<",
{
@@ -201,12 +209,18 @@
{
"parentPluginId": "serverless",
"id": "def-public.ServerlessPluginStart.initNavigation.$1",
- "type": "string",
+ "type": "CompoundType",
"tags": [],
"label": "id",
"description": [],
"signature": [
- "string"
+ {
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionId",
+ "text": "SolutionId"
+ }
],
"path": "x-pack/plugins/serverless/public/types.ts",
"deprecated": false,
diff --git a/api_docs/serverless.mdx b/api_docs/serverless.mdx
index 859fbb345a171..418fcba2bb493 100644
--- a/api_docs/serverless.mdx
+++ b/api_docs/serverless.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/serverless
title: "serverless"
image: https://source.unsplash.com/400x175/?github
description: API docs for the serverless plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'serverless']
---
import serverlessObj from './serverless.devdocs.json';
diff --git a/api_docs/serverless_observability.mdx b/api_docs/serverless_observability.mdx
index 119cbf055236f..207120e0af381 100644
--- a/api_docs/serverless_observability.mdx
+++ b/api_docs/serverless_observability.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/serverlessObservability
title: "serverlessObservability"
image: https://source.unsplash.com/400x175/?github
description: API docs for the serverlessObservability plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'serverlessObservability']
---
import serverlessObservabilityObj from './serverless_observability.devdocs.json';
diff --git a/api_docs/serverless_search.mdx b/api_docs/serverless_search.mdx
index bc019b96705cd..1f369bc489146 100644
--- a/api_docs/serverless_search.mdx
+++ b/api_docs/serverless_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/serverlessSearch
title: "serverlessSearch"
image: https://source.unsplash.com/400x175/?github
description: API docs for the serverlessSearch plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'serverlessSearch']
---
import serverlessSearchObj from './serverless_search.devdocs.json';
diff --git a/api_docs/session_view.mdx b/api_docs/session_view.mdx
index 3d9561a35256a..6519f810a35f9 100644
--- a/api_docs/session_view.mdx
+++ b/api_docs/session_view.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/sessionView
title: "sessionView"
image: https://source.unsplash.com/400x175/?github
description: API docs for the sessionView plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'sessionView']
---
import sessionViewObj from './session_view.devdocs.json';
diff --git a/api_docs/share.mdx b/api_docs/share.mdx
index 7d18c6de86d52..f789f022797d4 100644
--- a/api_docs/share.mdx
+++ b/api_docs/share.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/share
title: "share"
image: https://source.unsplash.com/400x175/?github
description: API docs for the share plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'share']
---
import shareObj from './share.devdocs.json';
diff --git a/api_docs/slo.mdx b/api_docs/slo.mdx
index a75390350f9f7..60c86ac71416c 100644
--- a/api_docs/slo.mdx
+++ b/api_docs/slo.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/slo
title: "slo"
image: https://source.unsplash.com/400x175/?github
description: API docs for the slo plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'slo']
---
import sloObj from './slo.devdocs.json';
diff --git a/api_docs/snapshot_restore.mdx b/api_docs/snapshot_restore.mdx
index d2369141997f9..4096f521d93bc 100644
--- a/api_docs/snapshot_restore.mdx
+++ b/api_docs/snapshot_restore.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/snapshotRestore
title: "snapshotRestore"
image: https://source.unsplash.com/400x175/?github
description: API docs for the snapshotRestore plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'snapshotRestore']
---
import snapshotRestoreObj from './snapshot_restore.devdocs.json';
diff --git a/api_docs/spaces.devdocs.json b/api_docs/spaces.devdocs.json
index e87c7b38031a0..93ea371a06d61 100644
--- a/api_docs/spaces.devdocs.json
+++ b/api_docs/spaces.devdocs.json
@@ -5154,11 +5154,11 @@
"description": [],
"signature": [
{
- "pluginId": "cloud",
- "scope": "common",
- "docId": "kibCloudPluginApi",
- "section": "def-common.OnBoardingDefaultSolution",
- "text": "OnBoardingDefaultSolution"
+ "pluginId": "@kbn/core-chrome-browser",
+ "scope": "public",
+ "docId": "kibKbnCoreChromeBrowserPluginApi",
+ "section": "def-public.SolutionId",
+ "text": "SolutionId"
},
" | \"classic\""
],
diff --git a/api_docs/spaces.mdx b/api_docs/spaces.mdx
index f98e067b161f6..5a08504ed7e6d 100644
--- a/api_docs/spaces.mdx
+++ b/api_docs/spaces.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/spaces
title: "spaces"
image: https://source.unsplash.com/400x175/?github
description: API docs for the spaces plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'spaces']
---
import spacesObj from './spaces.devdocs.json';
diff --git a/api_docs/stack_alerts.mdx b/api_docs/stack_alerts.mdx
index 79d84d156e446..8269f73230ba0 100644
--- a/api_docs/stack_alerts.mdx
+++ b/api_docs/stack_alerts.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/stackAlerts
title: "stackAlerts"
image: https://source.unsplash.com/400x175/?github
description: API docs for the stackAlerts plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'stackAlerts']
---
import stackAlertsObj from './stack_alerts.devdocs.json';
diff --git a/api_docs/stack_connectors.mdx b/api_docs/stack_connectors.mdx
index 02c876f06f7b9..133ac743ba0eb 100644
--- a/api_docs/stack_connectors.mdx
+++ b/api_docs/stack_connectors.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/stackConnectors
title: "stackConnectors"
image: https://source.unsplash.com/400x175/?github
description: API docs for the stackConnectors plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'stackConnectors']
---
import stackConnectorsObj from './stack_connectors.devdocs.json';
diff --git a/api_docs/task_manager.mdx b/api_docs/task_manager.mdx
index bea2dd4597ecd..18089bf93c662 100644
--- a/api_docs/task_manager.mdx
+++ b/api_docs/task_manager.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/taskManager
title: "taskManager"
image: https://source.unsplash.com/400x175/?github
description: API docs for the taskManager plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'taskManager']
---
import taskManagerObj from './task_manager.devdocs.json';
diff --git a/api_docs/telemetry.mdx b/api_docs/telemetry.mdx
index 55d4c9d325ce3..50d0b5f2333c8 100644
--- a/api_docs/telemetry.mdx
+++ b/api_docs/telemetry.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/telemetry
title: "telemetry"
image: https://source.unsplash.com/400x175/?github
description: API docs for the telemetry plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetry']
---
import telemetryObj from './telemetry.devdocs.json';
diff --git a/api_docs/telemetry_collection_manager.mdx b/api_docs/telemetry_collection_manager.mdx
index 81d969fa7cadd..fedfbf093a1cb 100644
--- a/api_docs/telemetry_collection_manager.mdx
+++ b/api_docs/telemetry_collection_manager.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/telemetryCollectionManager
title: "telemetryCollectionManager"
image: https://source.unsplash.com/400x175/?github
description: API docs for the telemetryCollectionManager plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetryCollectionManager']
---
import telemetryCollectionManagerObj from './telemetry_collection_manager.devdocs.json';
diff --git a/api_docs/telemetry_collection_xpack.mdx b/api_docs/telemetry_collection_xpack.mdx
index 1e2a8b6f5b673..e64f45318bbd8 100644
--- a/api_docs/telemetry_collection_xpack.mdx
+++ b/api_docs/telemetry_collection_xpack.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/telemetryCollectionXpack
title: "telemetryCollectionXpack"
image: https://source.unsplash.com/400x175/?github
description: API docs for the telemetryCollectionXpack plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetryCollectionXpack']
---
import telemetryCollectionXpackObj from './telemetry_collection_xpack.devdocs.json';
diff --git a/api_docs/telemetry_management_section.mdx b/api_docs/telemetry_management_section.mdx
index f3cdde6559d5d..4c451d5da0555 100644
--- a/api_docs/telemetry_management_section.mdx
+++ b/api_docs/telemetry_management_section.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/telemetryManagementSection
title: "telemetryManagementSection"
image: https://source.unsplash.com/400x175/?github
description: API docs for the telemetryManagementSection plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetryManagementSection']
---
import telemetryManagementSectionObj from './telemetry_management_section.devdocs.json';
diff --git a/api_docs/threat_intelligence.mdx b/api_docs/threat_intelligence.mdx
index 5f10b8c66204b..a23caf59f6ecb 100644
--- a/api_docs/threat_intelligence.mdx
+++ b/api_docs/threat_intelligence.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/threatIntelligence
title: "threatIntelligence"
image: https://source.unsplash.com/400x175/?github
description: API docs for the threatIntelligence plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'threatIntelligence']
---
import threatIntelligenceObj from './threat_intelligence.devdocs.json';
diff --git a/api_docs/timelines.mdx b/api_docs/timelines.mdx
index afc7d412e0652..bf0519ab7d43e 100644
--- a/api_docs/timelines.mdx
+++ b/api_docs/timelines.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/timelines
title: "timelines"
image: https://source.unsplash.com/400x175/?github
description: API docs for the timelines plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'timelines']
---
import timelinesObj from './timelines.devdocs.json';
diff --git a/api_docs/transform.mdx b/api_docs/transform.mdx
index 434ddda364510..adf88eb9d5b29 100644
--- a/api_docs/transform.mdx
+++ b/api_docs/transform.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/transform
title: "transform"
image: https://source.unsplash.com/400x175/?github
description: API docs for the transform plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'transform']
---
import transformObj from './transform.devdocs.json';
diff --git a/api_docs/triggers_actions_ui.mdx b/api_docs/triggers_actions_ui.mdx
index 0ab7e0f12ef48..aae0a1a79d30c 100644
--- a/api_docs/triggers_actions_ui.mdx
+++ b/api_docs/triggers_actions_ui.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/triggersActionsUi
title: "triggersActionsUi"
image: https://source.unsplash.com/400x175/?github
description: API docs for the triggersActionsUi plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'triggersActionsUi']
---
import triggersActionsUiObj from './triggers_actions_ui.devdocs.json';
diff --git a/api_docs/ui_actions.mdx b/api_docs/ui_actions.mdx
index 968a03e42c2ec..11c00bbe76910 100644
--- a/api_docs/ui_actions.mdx
+++ b/api_docs/ui_actions.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/uiActions
title: "uiActions"
image: https://source.unsplash.com/400x175/?github
description: API docs for the uiActions plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'uiActions']
---
import uiActionsObj from './ui_actions.devdocs.json';
diff --git a/api_docs/ui_actions_enhanced.mdx b/api_docs/ui_actions_enhanced.mdx
index 4ef808051e35d..255d8cad3796d 100644
--- a/api_docs/ui_actions_enhanced.mdx
+++ b/api_docs/ui_actions_enhanced.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/uiActionsEnhanced
title: "uiActionsEnhanced"
image: https://source.unsplash.com/400x175/?github
description: API docs for the uiActionsEnhanced plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'uiActionsEnhanced']
---
import uiActionsEnhancedObj from './ui_actions_enhanced.devdocs.json';
diff --git a/api_docs/unified_doc_viewer.mdx b/api_docs/unified_doc_viewer.mdx
index 90df59a54843d..ff623718d6e77 100644
--- a/api_docs/unified_doc_viewer.mdx
+++ b/api_docs/unified_doc_viewer.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/unifiedDocViewer
title: "unifiedDocViewer"
image: https://source.unsplash.com/400x175/?github
description: API docs for the unifiedDocViewer plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'unifiedDocViewer']
---
import unifiedDocViewerObj from './unified_doc_viewer.devdocs.json';
diff --git a/api_docs/unified_histogram.mdx b/api_docs/unified_histogram.mdx
index 0565808a7016c..79b1306473caa 100644
--- a/api_docs/unified_histogram.mdx
+++ b/api_docs/unified_histogram.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/unifiedHistogram
title: "unifiedHistogram"
image: https://source.unsplash.com/400x175/?github
description: API docs for the unifiedHistogram plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'unifiedHistogram']
---
import unifiedHistogramObj from './unified_histogram.devdocs.json';
diff --git a/api_docs/unified_search.mdx b/api_docs/unified_search.mdx
index b35b416ee65ba..b7f2fec64c432 100644
--- a/api_docs/unified_search.mdx
+++ b/api_docs/unified_search.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/unifiedSearch
title: "unifiedSearch"
image: https://source.unsplash.com/400x175/?github
description: API docs for the unifiedSearch plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'unifiedSearch']
---
import unifiedSearchObj from './unified_search.devdocs.json';
diff --git a/api_docs/unified_search_autocomplete.mdx b/api_docs/unified_search_autocomplete.mdx
index 26f83b7ae54d1..4ad7a531f0d51 100644
--- a/api_docs/unified_search_autocomplete.mdx
+++ b/api_docs/unified_search_autocomplete.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/unifiedSearch-autocomplete
title: "unifiedSearch.autocomplete"
image: https://source.unsplash.com/400x175/?github
description: API docs for the unifiedSearch.autocomplete plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'unifiedSearch.autocomplete']
---
import unifiedSearchAutocompleteObj from './unified_search_autocomplete.devdocs.json';
diff --git a/api_docs/uptime.mdx b/api_docs/uptime.mdx
index c8d931f06102c..35f7eb900360e 100644
--- a/api_docs/uptime.mdx
+++ b/api_docs/uptime.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/uptime
title: "uptime"
image: https://source.unsplash.com/400x175/?github
description: API docs for the uptime plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'uptime']
---
import uptimeObj from './uptime.devdocs.json';
diff --git a/api_docs/url_forwarding.mdx b/api_docs/url_forwarding.mdx
index 431a41febd3cc..296a53bcaa6a7 100644
--- a/api_docs/url_forwarding.mdx
+++ b/api_docs/url_forwarding.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/urlForwarding
title: "urlForwarding"
image: https://source.unsplash.com/400x175/?github
description: API docs for the urlForwarding plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'urlForwarding']
---
import urlForwardingObj from './url_forwarding.devdocs.json';
diff --git a/api_docs/usage_collection.mdx b/api_docs/usage_collection.mdx
index d93b0a6cd665b..7d0944c690494 100644
--- a/api_docs/usage_collection.mdx
+++ b/api_docs/usage_collection.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/usageCollection
title: "usageCollection"
image: https://source.unsplash.com/400x175/?github
description: API docs for the usageCollection plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'usageCollection']
---
import usageCollectionObj from './usage_collection.devdocs.json';
diff --git a/api_docs/ux.mdx b/api_docs/ux.mdx
index 77f5d871e7323..61b4cb3fc2ad1 100644
--- a/api_docs/ux.mdx
+++ b/api_docs/ux.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/ux
title: "ux"
image: https://source.unsplash.com/400x175/?github
description: API docs for the ux plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ux']
---
import uxObj from './ux.devdocs.json';
diff --git a/api_docs/vis_default_editor.mdx b/api_docs/vis_default_editor.mdx
index a27fcc1e88025..c8a7afdac19f9 100644
--- a/api_docs/vis_default_editor.mdx
+++ b/api_docs/vis_default_editor.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visDefaultEditor
title: "visDefaultEditor"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visDefaultEditor plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visDefaultEditor']
---
import visDefaultEditorObj from './vis_default_editor.devdocs.json';
diff --git a/api_docs/vis_type_gauge.mdx b/api_docs/vis_type_gauge.mdx
index 763767b3aaa24..2fa5b3b9853fc 100644
--- a/api_docs/vis_type_gauge.mdx
+++ b/api_docs/vis_type_gauge.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeGauge
title: "visTypeGauge"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeGauge plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeGauge']
---
import visTypeGaugeObj from './vis_type_gauge.devdocs.json';
diff --git a/api_docs/vis_type_heatmap.mdx b/api_docs/vis_type_heatmap.mdx
index c253f7ccdf01b..8f0e2e61162ca 100644
--- a/api_docs/vis_type_heatmap.mdx
+++ b/api_docs/vis_type_heatmap.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeHeatmap
title: "visTypeHeatmap"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeHeatmap plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeHeatmap']
---
import visTypeHeatmapObj from './vis_type_heatmap.devdocs.json';
diff --git a/api_docs/vis_type_pie.mdx b/api_docs/vis_type_pie.mdx
index 27eb1651a9a7c..0f2968fde504e 100644
--- a/api_docs/vis_type_pie.mdx
+++ b/api_docs/vis_type_pie.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypePie
title: "visTypePie"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypePie plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypePie']
---
import visTypePieObj from './vis_type_pie.devdocs.json';
diff --git a/api_docs/vis_type_table.mdx b/api_docs/vis_type_table.mdx
index 723419b1f9007..23be7ae9f9991 100644
--- a/api_docs/vis_type_table.mdx
+++ b/api_docs/vis_type_table.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeTable
title: "visTypeTable"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeTable plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeTable']
---
import visTypeTableObj from './vis_type_table.devdocs.json';
diff --git a/api_docs/vis_type_timelion.mdx b/api_docs/vis_type_timelion.mdx
index c17f7e3223cce..e5a5bcb4a4a2c 100644
--- a/api_docs/vis_type_timelion.mdx
+++ b/api_docs/vis_type_timelion.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeTimelion
title: "visTypeTimelion"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeTimelion plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeTimelion']
---
import visTypeTimelionObj from './vis_type_timelion.devdocs.json';
diff --git a/api_docs/vis_type_timeseries.mdx b/api_docs/vis_type_timeseries.mdx
index 36fd16da3ce48..0637b99db10e4 100644
--- a/api_docs/vis_type_timeseries.mdx
+++ b/api_docs/vis_type_timeseries.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeTimeseries
title: "visTypeTimeseries"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeTimeseries plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeTimeseries']
---
import visTypeTimeseriesObj from './vis_type_timeseries.devdocs.json';
diff --git a/api_docs/vis_type_vega.mdx b/api_docs/vis_type_vega.mdx
index b3e257bd42b44..df3fe33873bad 100644
--- a/api_docs/vis_type_vega.mdx
+++ b/api_docs/vis_type_vega.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeVega
title: "visTypeVega"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeVega plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeVega']
---
import visTypeVegaObj from './vis_type_vega.devdocs.json';
diff --git a/api_docs/vis_type_vislib.mdx b/api_docs/vis_type_vislib.mdx
index 80648239ecf0b..21327a8338052 100644
--- a/api_docs/vis_type_vislib.mdx
+++ b/api_docs/vis_type_vislib.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeVislib
title: "visTypeVislib"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeVislib plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeVislib']
---
import visTypeVislibObj from './vis_type_vislib.devdocs.json';
diff --git a/api_docs/vis_type_xy.mdx b/api_docs/vis_type_xy.mdx
index 7b8868671e502..7f41f4c97200a 100644
--- a/api_docs/vis_type_xy.mdx
+++ b/api_docs/vis_type_xy.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visTypeXy
title: "visTypeXy"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visTypeXy plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeXy']
---
import visTypeXyObj from './vis_type_xy.devdocs.json';
diff --git a/api_docs/visualizations.mdx b/api_docs/visualizations.mdx
index 76f493dae88d7..c85b2fe1f41bf 100644
--- a/api_docs/visualizations.mdx
+++ b/api_docs/visualizations.mdx
@@ -8,7 +8,7 @@ slug: /kibana-dev-docs/api/visualizations
title: "visualizations"
image: https://source.unsplash.com/400x175/?github
description: API docs for the visualizations plugin
-date: 2024-10-31
+date: 2024-11-01
tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visualizations']
---
import visualizationsObj from './visualizations.devdocs.json';
diff --git a/docs/user/dashboard/create-dashboards.asciidoc b/docs/user/dashboard/create-dashboards.asciidoc
index b07b4e88a684a..8b0d5e5f524fd 100644
--- a/docs/user/dashboard/create-dashboards.asciidoc
+++ b/docs/user/dashboard/create-dashboards.asciidoc
@@ -83,6 +83,7 @@ image::https://images.contentstack.io/v3/assets/bltefdd0b53724fa2ce/bltf75cdb828
[[save-dashboards]]
. **Save** the dashboard. You can then leave the **Edit** mode and *Switch to view mode*.
+NOTE: Managed dashboards can't be edited directly, but you can <> them and edit these duplicates.
[[reset-the-dashboard]]
=== Reset dashboard changes
@@ -155,6 +156,24 @@ Copy panels from one dashboard to another dashboard.
[role="screenshot"]
image:https://images.contentstack.io/v3/assets/bltefdd0b53724fa2ce/blt64206db263cf5514/66f49286833cffb09bebd18d/copy-to-dashboard-8.15.0.gif[Copy a panel to another dashboard, width 30%]
+[[duplicate-dashboards]]
+== Duplicate dashboards
+
+. Open the dashboard you want to duplicate.
+
+. In *View* mode, click *Duplicate* in the toolbar.
+
+. In the *Duplicate dashboard* window, enter a title and optional description and tags.
+
+. Click *Save*.
+
+You will be redirected to the duplicated dashboard.
+
+To duplicate a managed dashboard, follow the instructions above or click the *Managed* badge in the toolbar. Then click *Duplicate* in the dialogue that appears.
+
+[role="screenshot"]
+image::images/managed-dashboard-popover-8.16.0.png[Managed badge dialog with Duplicate button, width=40%]
+
== Import dashboards
You can import dashboards from the **Saved Objects** page under **Stack Management**. Refer to <>.
diff --git a/docs/user/dashboard/dashboard.asciidoc b/docs/user/dashboard/dashboard.asciidoc
index 5ca198c9831af..2bc6738516f15 100644
--- a/docs/user/dashboard/dashboard.asciidoc
+++ b/docs/user/dashboard/dashboard.asciidoc
@@ -17,7 +17,7 @@ There are several <> in {kib} that let you create
// add link to sharing section
At any time, you can <> you've created with your team, in {kib} or outside.
-Some dashboards are created and managed by the system, and are identified as `managed` in your list of of dashboards. This generally happens when you set up an integration to add data. You can't edit managed dashboards directly, but you can duplicate them and edit these duplicates.
+Some dashboards are created and managed by the system, and are identified as `managed` in your list of dashboards. This generally happens when you set up an integration to add data. You can't edit managed dashboards directly, but you can <> them and edit these duplicates.
--
diff --git a/docs/user/dashboard/drilldowns.asciidoc b/docs/user/dashboard/drilldowns.asciidoc
index 6b3a6d80ecdda..cb568d97e69ee 100644
--- a/docs/user/dashboard/drilldowns.asciidoc
+++ b/docs/user/dashboard/drilldowns.asciidoc
@@ -1,6 +1,6 @@
[role="xpack"]
[[drilldowns]]
-=== Drilldowns
+=== Add drilldowns
Panels have built-in interactive capabilities that apply filters to the dashboard data. For example, when you drag a time range or click a pie slice, a filter for the time range or pie slice is applied. Drilldowns let you customize the interactive behavior while keeping the context of the interaction.
diff --git a/docs/user/dashboard/images/managed-dashboard-popover-8.16.0.png b/docs/user/dashboard/images/managed-dashboard-popover-8.16.0.png
new file mode 100644
index 0000000000000..b1cd0562a42c7
Binary files /dev/null and b/docs/user/dashboard/images/managed-dashboard-popover-8.16.0.png differ
diff --git a/oas_docs/output/kibana.serverless.yaml b/oas_docs/output/kibana.serverless.yaml
index e88f038430235..1e7b41ea2c1af 100644
--- a/oas_docs/output/kibana.serverless.yaml
+++ b/oas_docs/output/kibana.serverless.yaml
@@ -4736,49 +4736,110 @@ paths:
post:
description: Create a new agent key for APM.
operationId: createAgentKey
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
requestBody:
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- name:
- type: string
- privileges:
- items:
- enum:
- - event:write
- - config_agent:read
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_agent_keys_object'
required: true
responses:
'200':
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- api_key:
- type: string
- encoded:
- type: string
- expiration:
- format: int64
- type: integer
- id:
- type: string
- name:
- type: string
+ $ref: '#/components/schemas/APM_UI_agent_keys_response'
description: Agent key created successfully
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
summary: Create an APM agent key
tags:
- APM agent keys
+ /api/apm/fleet/apm_server_schema:
+ post:
+ operationId: saveApmServerSchema
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ type: object
+ properties:
+ schema:
+ additionalProperties: true
+ description: Schema object
+ example:
+ foo: bar
+ type: object
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ additionalProperties: false
+ type: object
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Save APM server schema
+ tags:
+ - APM server schema
/api/apm/services/{serviceName}/annotation:
post:
description: Create a new annotation for a specific service.
operationId: createAnnotation
parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
- description: The name of the service
in: path
name: serviceName
@@ -4789,63 +4850,39 @@ paths:
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- '@timestamp':
- type: string
- message:
- type: string
- service:
- type: object
- properties:
- environment:
- type: string
- version:
- type: string
- tags:
- items:
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_create_annotation_object'
required: true
responses:
'200':
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- _id:
- type: string
- _index:
- type: string
- _source:
- type: object
- properties:
- '@timestamp':
- type: string
- annotation:
- type: string
- event:
- type: object
- properties:
- created:
- type: string
- message:
- type: string
- service:
- type: object
- properties:
- environment:
- type: string
- name:
- type: string
- version:
- type: string
- tags:
- items:
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_create_annotation_response'
description: Annotation created successfully
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
summary: Create a service annotation
tags:
- APM annotations
@@ -4854,6 +4891,7 @@ paths:
description: Search for annotations related to a specific service.
operationId: getAnnotation
parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
- description: The name of the service
in: path
name: serviceName
@@ -4883,27 +4921,484 @@ paths:
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- annotations:
- items:
- type: object
- properties:
- '@timestamp':
- type: number
- id:
- type: string
- text:
- type: string
- type:
- enum:
- - version
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_annotation_search_response'
description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
summary: Search for annotations
tags:
- APM annotations
+ /api/apm/settings/agent-configuration:
+ delete:
+ operationId: deleteAgentConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: >-
+ #/components/schemas/APM_UI_delete_agent_configurations_response
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Delete agent configuration
+ tags:
+ - APM agent configuration
+ get:
+ operationId: getAgentConfigurations
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_agent_configurations_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get a list of agent configurations
+ tags:
+ - APM agent configuration
+ put:
+ operationId: createUpdateAgentConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ - description: If the config exists ?overwrite=true is required
+ in: query
+ name: overwrite
+ schema:
+ type: boolean
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_agent_configuration_intake_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ additionalProperties: false
+ type: object
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Create or update agent configuration
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/agent_name:
+ get:
+ description: Retrieve `agentName` for a service.
+ operationId: getAgentNameForService
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: The name of the service
+ example: node
+ in: query
+ name: serviceName
+ required: true
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_service_agent_name_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get agent name for service
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/environments:
+ get:
+ operationId: getEnvironmentsForService
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: The name of the service
+ in: query
+ name: serviceName
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_service_environments_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get environments for service
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/search:
+ post:
+ description: >
+ This endpoint allows to search for single agent configuration and update
+ 'applied_by_agent' field.
+ operationId: searchSingleConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_search_agent_configuration_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: >-
+ #/components/schemas/APM_UI_search_agent_configuration_response
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Lookup single agent configuration
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/view:
+ get:
+ operationId: getSingleAgentConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: Service name
+ example: node
+ in: query
+ name: name
+ schema:
+ type: string
+ - description: Service environment
+ example: prod
+ in: query
+ name: environment
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: >-
+ #/components/schemas/APM_UI_single_agent_configuration_response
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get single agent configuration
+ tags:
+ - APM agent configuration
+ /api/apm/sourcemaps:
+ get:
+ description: Returns an array of Fleet artifacts, including source map uploads.
+ operationId: getSourceMaps
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: Page number
+ in: query
+ name: page
+ schema:
+ type: number
+ - description: Number of records per page
+ in: query
+ name: perPage
+ schema:
+ type: number
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_source_maps_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
+ '501':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_501_response'
+ description: Not Implemented response
+ summary: Get source maps
+ tags:
+ - APM sourcemaps
+ post:
+ description: Upload a source map for a specific service and version.
+ operationId: uploadSourceMap
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ multipart/form-data; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_upload_source_map_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_upload_source_maps_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
+ '501':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_501_response'
+ description: Not Implemented response
+ summary: Upload source map
+ tags:
+ - APM sourcemaps
+ /api/apm/sourcemaps/{id}:
+ delete:
+ description: Delete a previously uploaded source map.
+ operationId: deleteSourceMap
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ - description: Source map identifier
+ in: path
+ name: id
+ required: true
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ additionalProperties: false
+ type: object
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
+ '501':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_501_response'
+ description: Not Implemented response
+ summary: Delete source map
+ tags:
+ - APM sourcemaps
/api/asset_criticality:
delete:
description: Delete the asset criticality record for a specific entity.
@@ -39931,6 +40426,24 @@ components:
title: Kibana Sample Data Logs
type: index-pattern
parameters:
+ APM_UI_elastic_api_version:
+ description: The version of the API to use
+ in: header
+ name: elastic-api-version
+ required: true
+ schema:
+ default: '2023-10-31'
+ enum:
+ - '2023-10-31'
+ type: string
+ APM_UI_kbn_xsrf:
+ description: A required header to protect against CSRF attacks
+ in: header
+ name: kbn-xsrf
+ required: true
+ schema:
+ example: 'true'
+ type: string
Data_views_field_name:
description: The name of the runtime field.
in: path
@@ -39997,6 +40510,471 @@ components:
example: default
type: string
schemas:
+ APM_UI_400_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Not Found
+ type: string
+ message:
+ description: Error message
+ example: Not Found
+ type: string
+ statusCode:
+ description: Error status code
+ example: 400
+ type: number
+ APM_UI_401_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Unauthorized
+ type: string
+ message:
+ description: Error message
+ type: string
+ statusCode:
+ description: Error status code
+ example: 401
+ type: number
+ APM_UI_403_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Forbidden
+ type: string
+ message:
+ description: Error message
+ type: string
+ statusCode:
+ description: Error status code
+ example: 403
+ type: number
+ APM_UI_404_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Not Found
+ type: string
+ message:
+ description: Error message
+ example: Not Found
+ type: string
+ statusCode:
+ description: Error status code
+ example: 404
+ type: number
+ APM_UI_500_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Internal Server Error
+ type: string
+ message:
+ description: Error message
+ type: string
+ statusCode:
+ description: Error status code
+ example: 500
+ type: number
+ APM_UI_501_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Not Implemented
+ type: string
+ message:
+ description: Error message
+ example: Not Implemented
+ type: string
+ statusCode:
+ description: Error status code
+ example: 501
+ type: number
+ APM_UI_agent_configuration_intake_object:
+ type: object
+ properties:
+ agent_name:
+ description: Agent name
+ type: string
+ service:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ settings:
+ $ref: '#/components/schemas/APM_UI_settings_object'
+ required:
+ - service
+ - settings
+ APM_UI_agent_configuration_object:
+ description: Agent configuration
+ type: object
+ properties:
+ '@timestamp':
+ description: Timestamp
+ example: 1730194190636
+ type: number
+ agent_name:
+ description: Agent name
+ type: string
+ applied_by_agent:
+ description: Applied by agent
+ example: true
+ type: boolean
+ etag:
+ description: Etag
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ type: string
+ service:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ settings:
+ $ref: '#/components/schemas/APM_UI_settings_object'
+ required:
+ - service
+ - settings
+ - '@timestamp'
+ - etag
+ APM_UI_agent_configurations_response:
+ type: object
+ properties:
+ configurations:
+ description: Agent configuration
+ items:
+ $ref: '#/components/schemas/APM_UI_agent_configuration_object'
+ type: array
+ APM_UI_agent_keys_object:
+ type: object
+ properties:
+ name:
+ description: Agent name
+ type: string
+ privileges:
+ description: Privileges configuration
+ items:
+ enum:
+ - event:write
+ - config_agent:read
+ type: string
+ type: array
+ required:
+ - name
+ - privileges
+ APM_UI_agent_keys_response:
+ type: object
+ properties:
+ agentKey:
+ description: Agent key
+ type: object
+ properties:
+ api_key:
+ type: string
+ encoded:
+ type: string
+ expiration:
+ format: int64
+ type: integer
+ id:
+ type: string
+ name:
+ type: string
+ required:
+ - id
+ - name
+ - api_key
+ - encoded
+ APM_UI_annotation_search_response:
+ type: object
+ properties:
+ annotations:
+ description: Annotations
+ items:
+ type: object
+ properties:
+ '@timestamp':
+ type: number
+ id:
+ type: string
+ text:
+ type: string
+ type:
+ enum:
+ - version
+ type: string
+ type: array
+ APM_UI_base_source_map_object:
+ type: object
+ properties:
+ compressionAlgorithm:
+ description: Compression Algorithm
+ type: string
+ created:
+ description: Created date
+ type: string
+ decodedSha256:
+ description: Decoded SHA-256
+ type: string
+ decodedSize:
+ description: Decoded size
+ type: number
+ encodedSha256:
+ description: Encoded SHA-256
+ type: string
+ encodedSize:
+ description: Encoded size
+ type: number
+ encryptionAlgorithm:
+ description: Encryption Algorithm
+ type: string
+ id:
+ description: Identifier
+ type: string
+ identifier:
+ description: Identifier
+ type: string
+ packageName:
+ description: Package name
+ type: string
+ relative_url:
+ description: Relative URL
+ type: string
+ type:
+ description: Type
+ type: string
+ APM_UI_create_annotation_object:
+ type: object
+ properties:
+ '@timestamp':
+ description: Timestamp
+ type: string
+ message:
+ description: Message
+ type: string
+ service:
+ description: Service
+ type: object
+ properties:
+ environment:
+ type: string
+ version:
+ type: string
+ required:
+ - version
+ tags:
+ description: Tags
+ items:
+ type: string
+ type: array
+ required:
+ - '@timestamp'
+ - service
+ APM_UI_create_annotation_response:
+ type: object
+ properties:
+ _id:
+ description: Identifier
+ type: string
+ _index:
+ description: Index
+ type: string
+ _source:
+ description: Response
+ type: object
+ properties:
+ '@timestamp':
+ type: string
+ annotation:
+ type: object
+ properties:
+ title:
+ type: string
+ type:
+ type: string
+ event:
+ type: object
+ properties:
+ created:
+ type: string
+ message:
+ type: string
+ service:
+ type: object
+ properties:
+ environment:
+ type: string
+ name:
+ type: string
+ version:
+ type: string
+ tags:
+ items:
+ type: string
+ type: array
+ APM_UI_delete_agent_configurations_response:
+ type: object
+ properties:
+ result:
+ description: Result
+ type: string
+ APM_UI_search_agent_configuration_object:
+ type: object
+ properties:
+ etag:
+ description: If etags match then `applied_by_agent` field will be set to `true`
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ type: string
+ mark_as_applied_by_agent:
+ description: >
+ `markAsAppliedByAgent=true` means "force setting it to true
+ regardless of etag".
+
+ This is needed for Jaeger agent that doesn't have etags
+ type: boolean
+ service:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ required:
+ - service
+ APM_UI_search_agent_configuration_response:
+ type: object
+ properties:
+ _id:
+ description: Identifier
+ type: string
+ _index:
+ description: Index
+ type: string
+ _score:
+ description: Score
+ type: number
+ _source:
+ $ref: '#/components/schemas/APM_UI_agent_configuration_object'
+ APM_UI_service_agent_name_response:
+ type: object
+ properties:
+ agentName:
+ description: Agent name
+ example: nodejs
+ type: string
+ APM_UI_service_environment_object:
+ type: object
+ properties:
+ alreadyConfigured:
+ description: Already configured
+ type: boolean
+ name:
+ description: Service environment name
+ example: ALL_OPTION_VALUE
+ type: string
+ APM_UI_service_environments_response:
+ type: object
+ properties:
+ environments:
+ description: Service environment list
+ items:
+ $ref: '#/components/schemas/APM_UI_service_environment_object'
+ type: array
+ APM_UI_service_object:
+ description: Service
+ type: object
+ properties:
+ environment:
+ description: Environment
+ example: prod
+ type: string
+ name:
+ description: Name
+ example: node
+ type: string
+ APM_UI_settings_object:
+ additionalProperties:
+ type: string
+ description: Agent configuration settings
+ type: object
+ APM_UI_single_agent_configuration_response:
+ allOf:
+ - type: object
+ properties:
+ id:
+ type: string
+ required:
+ - id
+ - $ref: '#/components/schemas/APM_UI_agent_configuration_object'
+ APM_UI_source_maps_response:
+ type: object
+ properties:
+ artifacts:
+ description: Artifacts
+ items:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: object
+ properties:
+ bundleFilepath:
+ type: string
+ serviceName:
+ type: string
+ serviceVersion:
+ type: string
+ sourceMap:
+ type: object
+ properties:
+ file:
+ type: string
+ mappings:
+ type: string
+ sourceRoot:
+ type: string
+ sources:
+ items:
+ type: string
+ type: array
+ sourcesContent:
+ items:
+ type: string
+ type: array
+ version:
+ type: number
+ - $ref: '#/components/schemas/APM_UI_base_source_map_object'
+ type: array
+ APM_UI_upload_source_map_object:
+ type: object
+ properties:
+ bundle_filepath:
+ description: >-
+ The absolute path of the final bundle as used in the web
+ application.
+ type: string
+ service_name:
+ description: The name of the service that the service map should apply to.
+ type: string
+ service_version:
+ description: The version of the service that the service map should apply to.
+ type: string
+ sourcemap:
+ description: >
+ The source map. String or file upload. It must follow the
+
+ [source map revision 3
+ proposal](https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k).
+ format: binary
+ type: string
+ required:
+ - service_name
+ - service_version
+ - bundle_filepath
+ - sourcemap
+ APM_UI_upload_source_maps_response:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: string
+ - $ref: '#/components/schemas/APM_UI_base_source_map_object'
Data_views_400_response:
title: Bad request
type: object
@@ -51746,6 +52724,9 @@ security:
- apiKeyAuth: []
tags:
- name: alerting
+ - description: |
+ Adjust APM agent configuration without need to redeploy your application.
+ name: APM agent configuration
- description: >
Configure APM agent keys to authorize requests from APM agents to the APM
Server.
@@ -51755,6 +52736,10 @@ tags:
Annotations enable you to easily see how events are impacting the
performance of your applications.
name: APM annotations
+ - description: Create APM fleet server schema.
+ name: APM server schema
+ - description: Configure APM source maps.
+ name: APM sourcemaps
- name: connectors
- name: Data streams
- description: >-
diff --git a/oas_docs/output/kibana.yaml b/oas_docs/output/kibana.yaml
index 144c4a60f3e29..237974a87bbb2 100644
--- a/oas_docs/output/kibana.yaml
+++ b/oas_docs/output/kibana.yaml
@@ -5917,49 +5917,110 @@ paths:
post:
description: Create a new agent key for APM.
operationId: createAgentKey
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
requestBody:
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- name:
- type: string
- privileges:
- items:
- enum:
- - event:write
- - config_agent:read
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_agent_keys_object'
required: true
responses:
'200':
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- api_key:
- type: string
- encoded:
- type: string
- expiration:
- format: int64
- type: integer
- id:
- type: string
- name:
- type: string
+ $ref: '#/components/schemas/APM_UI_agent_keys_response'
description: Agent key created successfully
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
summary: Create an APM agent key
tags:
- APM agent keys
+ /api/apm/fleet/apm_server_schema:
+ post:
+ operationId: saveApmServerSchema
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ type: object
+ properties:
+ schema:
+ additionalProperties: true
+ description: Schema object
+ example:
+ foo: bar
+ type: object
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ additionalProperties: false
+ type: object
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Save APM server schema
+ tags:
+ - APM server schema
/api/apm/services/{serviceName}/annotation:
post:
description: Create a new annotation for a specific service.
operationId: createAnnotation
parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
- description: The name of the service
in: path
name: serviceName
@@ -5970,63 +6031,39 @@ paths:
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- '@timestamp':
- type: string
- message:
- type: string
- service:
- type: object
- properties:
- environment:
- type: string
- version:
- type: string
- tags:
- items:
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_create_annotation_object'
required: true
responses:
'200':
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- _id:
- type: string
- _index:
- type: string
- _source:
- type: object
- properties:
- '@timestamp':
- type: string
- annotation:
- type: string
- event:
- type: object
- properties:
- created:
- type: string
- message:
- type: string
- service:
- type: object
- properties:
- environment:
- type: string
- name:
- type: string
- version:
- type: string
- tags:
- items:
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_create_annotation_response'
description: Annotation created successfully
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
summary: Create a service annotation
tags:
- APM annotations
@@ -6035,6 +6072,7 @@ paths:
description: Search for annotations related to a specific service.
operationId: getAnnotation
parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
- description: The name of the service
in: path
name: serviceName
@@ -6064,27 +6102,484 @@ paths:
content:
application/json; Elastic-Api-Version=2023-10-31:
schema:
- type: object
- properties:
- annotations:
- items:
- type: object
- properties:
- '@timestamp':
- type: number
- id:
- type: string
- text:
- type: string
- type:
- enum:
- - version
- type: string
- type: array
+ $ref: '#/components/schemas/APM_UI_annotation_search_response'
description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
summary: Search for annotations
tags:
- APM annotations
+ /api/apm/settings/agent-configuration:
+ delete:
+ operationId: deleteAgentConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: >-
+ #/components/schemas/APM_UI_delete_agent_configurations_response
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Delete agent configuration
+ tags:
+ - APM agent configuration
+ get:
+ operationId: getAgentConfigurations
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_agent_configurations_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get a list of agent configurations
+ tags:
+ - APM agent configuration
+ put:
+ operationId: createUpdateAgentConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ - description: If the config exists ?overwrite=true is required
+ in: query
+ name: overwrite
+ schema:
+ type: boolean
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_agent_configuration_intake_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ additionalProperties: false
+ type: object
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Create or update agent configuration
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/agent_name:
+ get:
+ description: Retrieve `agentName` for a service.
+ operationId: getAgentNameForService
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: The name of the service
+ example: node
+ in: query
+ name: serviceName
+ required: true
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_service_agent_name_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get agent name for service
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/environments:
+ get:
+ operationId: getEnvironmentsForService
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: The name of the service
+ in: query
+ name: serviceName
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_service_environments_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get environments for service
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/search:
+ post:
+ description: >
+ This endpoint allows to search for single agent configuration and update
+ 'applied_by_agent' field.
+ operationId: searchSingleConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_search_agent_configuration_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: >-
+ #/components/schemas/APM_UI_search_agent_configuration_response
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Lookup single agent configuration
+ tags:
+ - APM agent configuration
+ /api/apm/settings/agent-configuration/view:
+ get:
+ operationId: getSingleAgentConfiguration
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: Service name
+ example: node
+ in: query
+ name: name
+ schema:
+ type: string
+ - description: Service environment
+ example: prod
+ in: query
+ name: environment
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: >-
+ #/components/schemas/APM_UI_single_agent_configuration_response
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '404':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_404_response'
+ description: Not found response
+ summary: Get single agent configuration
+ tags:
+ - APM agent configuration
+ /api/apm/sourcemaps:
+ get:
+ description: Returns an array of Fleet artifacts, including source map uploads.
+ operationId: getSourceMaps
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - description: Page number
+ in: query
+ name: page
+ schema:
+ type: number
+ - description: Number of records per page
+ in: query
+ name: perPage
+ schema:
+ type: number
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_source_maps_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
+ '501':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_501_response'
+ description: Not Implemented response
+ summary: Get source maps
+ tags:
+ - APM sourcemaps
+ post:
+ description: Upload a source map for a specific service and version.
+ operationId: uploadSourceMap
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ requestBody:
+ content:
+ multipart/form-data; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_upload_source_map_object'
+ required: true
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_upload_source_maps_response'
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
+ '501':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_501_response'
+ description: Not Implemented response
+ summary: Upload source map
+ tags:
+ - APM sourcemaps
+ /api/apm/sourcemaps/{id}:
+ delete:
+ description: Delete a previously uploaded source map.
+ operationId: deleteSourceMap
+ parameters:
+ - $ref: '#/components/parameters/APM_UI_elastic_api_version'
+ - $ref: '#/components/parameters/APM_UI_kbn_xsrf'
+ - description: Source map identifier
+ in: path
+ name: id
+ required: true
+ schema:
+ type: string
+ responses:
+ '200':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ additionalProperties: false
+ type: object
+ description: Successful response
+ '400':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_400_response'
+ description: Bad Request response
+ '401':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_401_response'
+ description: Unauthorized response
+ '403':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_403_response'
+ description: Forbidden response
+ '500':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_500_response'
+ description: Internal Server Error response
+ '501':
+ content:
+ application/json; Elastic-Api-Version=2023-10-31:
+ schema:
+ $ref: '#/components/schemas/APM_UI_501_response'
+ description: Not Implemented response
+ summary: Delete source map
+ tags:
+ - APM sourcemaps
/api/asset_criticality:
delete:
description: Delete the asset criticality record for a specific entity.
@@ -45568,6 +46063,24 @@ components:
required: true
schema:
type: string
+ APM_UI_elastic_api_version:
+ description: The version of the API to use
+ in: header
+ name: elastic-api-version
+ required: true
+ schema:
+ default: '2023-10-31'
+ enum:
+ - '2023-10-31'
+ type: string
+ APM_UI_kbn_xsrf:
+ description: A required header to protect against CSRF attacks
+ in: header
+ name: kbn-xsrf
+ required: true
+ schema:
+ example: 'true'
+ type: string
Cases_alert_id:
description: An identifier for the alert.
in: path
@@ -46059,6 +46572,471 @@ components:
description: Specifies the data type for the field.
example: scaled_float
type: string
+ APM_UI_400_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Not Found
+ type: string
+ message:
+ description: Error message
+ example: Not Found
+ type: string
+ statusCode:
+ description: Error status code
+ example: 400
+ type: number
+ APM_UI_401_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Unauthorized
+ type: string
+ message:
+ description: Error message
+ type: string
+ statusCode:
+ description: Error status code
+ example: 401
+ type: number
+ APM_UI_403_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Forbidden
+ type: string
+ message:
+ description: Error message
+ type: string
+ statusCode:
+ description: Error status code
+ example: 403
+ type: number
+ APM_UI_404_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Not Found
+ type: string
+ message:
+ description: Error message
+ example: Not Found
+ type: string
+ statusCode:
+ description: Error status code
+ example: 404
+ type: number
+ APM_UI_500_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Internal Server Error
+ type: string
+ message:
+ description: Error message
+ type: string
+ statusCode:
+ description: Error status code
+ example: 500
+ type: number
+ APM_UI_501_response:
+ type: object
+ properties:
+ error:
+ description: Error type
+ example: Not Implemented
+ type: string
+ message:
+ description: Error message
+ example: Not Implemented
+ type: string
+ statusCode:
+ description: Error status code
+ example: 501
+ type: number
+ APM_UI_agent_configuration_intake_object:
+ type: object
+ properties:
+ agent_name:
+ description: Agent name
+ type: string
+ service:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ settings:
+ $ref: '#/components/schemas/APM_UI_settings_object'
+ required:
+ - service
+ - settings
+ APM_UI_agent_configuration_object:
+ description: Agent configuration
+ type: object
+ properties:
+ '@timestamp':
+ description: Timestamp
+ example: 1730194190636
+ type: number
+ agent_name:
+ description: Agent name
+ type: string
+ applied_by_agent:
+ description: Applied by agent
+ example: true
+ type: boolean
+ etag:
+ description: Etag
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ type: string
+ service:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ settings:
+ $ref: '#/components/schemas/APM_UI_settings_object'
+ required:
+ - service
+ - settings
+ - '@timestamp'
+ - etag
+ APM_UI_agent_configurations_response:
+ type: object
+ properties:
+ configurations:
+ description: Agent configuration
+ items:
+ $ref: '#/components/schemas/APM_UI_agent_configuration_object'
+ type: array
+ APM_UI_agent_keys_object:
+ type: object
+ properties:
+ name:
+ description: Agent name
+ type: string
+ privileges:
+ description: Privileges configuration
+ items:
+ enum:
+ - event:write
+ - config_agent:read
+ type: string
+ type: array
+ required:
+ - name
+ - privileges
+ APM_UI_agent_keys_response:
+ type: object
+ properties:
+ agentKey:
+ description: Agent key
+ type: object
+ properties:
+ api_key:
+ type: string
+ encoded:
+ type: string
+ expiration:
+ format: int64
+ type: integer
+ id:
+ type: string
+ name:
+ type: string
+ required:
+ - id
+ - name
+ - api_key
+ - encoded
+ APM_UI_annotation_search_response:
+ type: object
+ properties:
+ annotations:
+ description: Annotations
+ items:
+ type: object
+ properties:
+ '@timestamp':
+ type: number
+ id:
+ type: string
+ text:
+ type: string
+ type:
+ enum:
+ - version
+ type: string
+ type: array
+ APM_UI_base_source_map_object:
+ type: object
+ properties:
+ compressionAlgorithm:
+ description: Compression Algorithm
+ type: string
+ created:
+ description: Created date
+ type: string
+ decodedSha256:
+ description: Decoded SHA-256
+ type: string
+ decodedSize:
+ description: Decoded size
+ type: number
+ encodedSha256:
+ description: Encoded SHA-256
+ type: string
+ encodedSize:
+ description: Encoded size
+ type: number
+ encryptionAlgorithm:
+ description: Encryption Algorithm
+ type: string
+ id:
+ description: Identifier
+ type: string
+ identifier:
+ description: Identifier
+ type: string
+ packageName:
+ description: Package name
+ type: string
+ relative_url:
+ description: Relative URL
+ type: string
+ type:
+ description: Type
+ type: string
+ APM_UI_create_annotation_object:
+ type: object
+ properties:
+ '@timestamp':
+ description: Timestamp
+ type: string
+ message:
+ description: Message
+ type: string
+ service:
+ description: Service
+ type: object
+ properties:
+ environment:
+ type: string
+ version:
+ type: string
+ required:
+ - version
+ tags:
+ description: Tags
+ items:
+ type: string
+ type: array
+ required:
+ - '@timestamp'
+ - service
+ APM_UI_create_annotation_response:
+ type: object
+ properties:
+ _id:
+ description: Identifier
+ type: string
+ _index:
+ description: Index
+ type: string
+ _source:
+ description: Response
+ type: object
+ properties:
+ '@timestamp':
+ type: string
+ annotation:
+ type: object
+ properties:
+ title:
+ type: string
+ type:
+ type: string
+ event:
+ type: object
+ properties:
+ created:
+ type: string
+ message:
+ type: string
+ service:
+ type: object
+ properties:
+ environment:
+ type: string
+ name:
+ type: string
+ version:
+ type: string
+ tags:
+ items:
+ type: string
+ type: array
+ APM_UI_delete_agent_configurations_response:
+ type: object
+ properties:
+ result:
+ description: Result
+ type: string
+ APM_UI_search_agent_configuration_object:
+ type: object
+ properties:
+ etag:
+ description: If etags match then `applied_by_agent` field will be set to `true`
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ type: string
+ mark_as_applied_by_agent:
+ description: >
+ `markAsAppliedByAgent=true` means "force setting it to true
+ regardless of etag".
+
+ This is needed for Jaeger agent that doesn't have etags
+ type: boolean
+ service:
+ $ref: '#/components/schemas/APM_UI_service_object'
+ required:
+ - service
+ APM_UI_search_agent_configuration_response:
+ type: object
+ properties:
+ _id:
+ description: Identifier
+ type: string
+ _index:
+ description: Index
+ type: string
+ _score:
+ description: Score
+ type: number
+ _source:
+ $ref: '#/components/schemas/APM_UI_agent_configuration_object'
+ APM_UI_service_agent_name_response:
+ type: object
+ properties:
+ agentName:
+ description: Agent name
+ example: nodejs
+ type: string
+ APM_UI_service_environment_object:
+ type: object
+ properties:
+ alreadyConfigured:
+ description: Already configured
+ type: boolean
+ name:
+ description: Service environment name
+ example: ALL_OPTION_VALUE
+ type: string
+ APM_UI_service_environments_response:
+ type: object
+ properties:
+ environments:
+ description: Service environment list
+ items:
+ $ref: '#/components/schemas/APM_UI_service_environment_object'
+ type: array
+ APM_UI_service_object:
+ description: Service
+ type: object
+ properties:
+ environment:
+ description: Environment
+ example: prod
+ type: string
+ name:
+ description: Name
+ example: node
+ type: string
+ APM_UI_settings_object:
+ additionalProperties:
+ type: string
+ description: Agent configuration settings
+ type: object
+ APM_UI_single_agent_configuration_response:
+ allOf:
+ - type: object
+ properties:
+ id:
+ type: string
+ required:
+ - id
+ - $ref: '#/components/schemas/APM_UI_agent_configuration_object'
+ APM_UI_source_maps_response:
+ type: object
+ properties:
+ artifacts:
+ description: Artifacts
+ items:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: object
+ properties:
+ bundleFilepath:
+ type: string
+ serviceName:
+ type: string
+ serviceVersion:
+ type: string
+ sourceMap:
+ type: object
+ properties:
+ file:
+ type: string
+ mappings:
+ type: string
+ sourceRoot:
+ type: string
+ sources:
+ items:
+ type: string
+ type: array
+ sourcesContent:
+ items:
+ type: string
+ type: array
+ version:
+ type: number
+ - $ref: '#/components/schemas/APM_UI_base_source_map_object'
+ type: array
+ APM_UI_upload_source_map_object:
+ type: object
+ properties:
+ bundle_filepath:
+ description: >-
+ The absolute path of the final bundle as used in the web
+ application.
+ type: string
+ service_name:
+ description: The name of the service that the service map should apply to.
+ type: string
+ service_version:
+ description: The version of the service that the service map should apply to.
+ type: string
+ sourcemap:
+ description: >
+ The source map. String or file upload. It must follow the
+
+ [source map revision 3
+ proposal](https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k).
+ format: binary
+ type: string
+ required:
+ - service_name
+ - service_version
+ - bundle_filepath
+ - sourcemap
+ APM_UI_upload_source_maps_response:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: string
+ - $ref: '#/components/schemas/APM_UI_base_source_map_object'
Cases_4xx_response:
properties:
error:
@@ -60117,6 +61095,9 @@ security:
- basicAuth: []
tags:
- name: alerting
+ - description: |
+ Adjust APM agent configuration without need to redeploy your application.
+ name: APM agent configuration
- description: >
Configure APM agent keys to authorize requests from APM agents to the APM
Server.
@@ -60126,6 +61107,10 @@ tags:
Annotations enable you to easily see how events are impacting the
performance of your applications.
name: APM annotations
+ - description: Create APM fleet server schema.
+ name: APM server schema
+ - description: Configure APM source maps.
+ name: APM sourcemaps
- description: Case APIs enable you to open and track issues.
name: cases
- name: connectors
diff --git a/oas_docs/scripts/merge_ess_oas.js b/oas_docs/scripts/merge_ess_oas.js
index 218e8dfa5b803..d8bc45e64c2f2 100644
--- a/oas_docs/scripts/merge_ess_oas.js
+++ b/oas_docs/scripts/merge_ess_oas.js
@@ -22,7 +22,7 @@ const { REPO_ROOT } = require('@kbn/repo-info');
`${REPO_ROOT}/packages/core/saved-objects/docs/openapi/bundled.yaml`,
// Observability Solution
- `${REPO_ROOT}/x-pack/plugins/observability_solution/apm/docs/openapi/apm.yaml`,
+ `${REPO_ROOT}/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.yaml`,
`${REPO_ROOT}/x-pack/plugins/observability_solution/slo/docs/openapi/slo/bundled.yaml`,
// Security solution
diff --git a/oas_docs/scripts/merge_serverless_oas.js b/oas_docs/scripts/merge_serverless_oas.js
index c66187dea8d8d..63d2df0f32d3f 100644
--- a/oas_docs/scripts/merge_serverless_oas.js
+++ b/oas_docs/scripts/merge_serverless_oas.js
@@ -20,7 +20,7 @@ const { REPO_ROOT } = require('@kbn/repo-info');
`${REPO_ROOT}/packages/core/saved-objects/docs/openapi/bundled_serverless.yaml`,
// Observability Solution
- `${REPO_ROOT}/x-pack/plugins/observability_solution/apm/docs/openapi/apm.yaml`,
+ `${REPO_ROOT}/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.yaml`,
`${REPO_ROOT}/x-pack/plugins/observability_solution/slo/docs/openapi/slo/bundled.yaml`,
// Security solution
diff --git a/package.json b/package.json
index fdd358de61b8f..4a91266058ccb 100644
--- a/package.json
+++ b/package.json
@@ -1018,7 +1018,7 @@
"@langchain/langgraph": "0.0.34",
"@langchain/openai": "^0.1.3",
"@langtrase/trace-attributes": "^3.0.8",
- "@launchdarkly/node-server-sdk": "^9.6.1",
+ "@launchdarkly/node-server-sdk": "^9.7.0",
"@launchdarkly/openfeature-node-server": "^1.0.0",
"@loaders.gl/core": "^3.4.7",
"@loaders.gl/json": "^3.4.7",
@@ -1161,7 +1161,7 @@
"kea": "^2.6.0",
"langchain": "^0.2.11",
"langsmith": "^0.1.55",
- "launchdarkly-js-client-sdk": "^3.4.0",
+ "launchdarkly-js-client-sdk": "^3.5.0",
"load-json-file": "^6.2.0",
"lodash": "^4.17.21",
"lru-cache": "^4.1.5",
@@ -1676,7 +1676,7 @@
"buildkite-test-collector": "^1.7.0",
"callsites": "^3.1.0",
"chance": "1.0.18",
- "chromedriver": "^129.0.0",
+ "chromedriver": "^130.0.1",
"clarify": "^2.2.0",
"clean-webpack-plugin": "^3.0.0",
"cli-progress": "^3.12.0",
@@ -1725,7 +1725,7 @@
"file-loader": "^4.2.0",
"find-cypress-specs": "^1.41.4",
"form-data": "^4.0.0",
- "geckodriver": "^4.4.4",
+ "geckodriver": "^4.5.1",
"gulp-brotli": "^3.0.0",
"gulp-postcss": "^9.0.1",
"gulp-terser": "^2.1.0",
diff --git a/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.test.ts b/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.test.ts
index d8c2b0b25874f..06c8e351bc445 100644
--- a/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.test.ts
+++ b/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.test.ts
@@ -19,6 +19,7 @@ import {
} from './import_saved_objects.test.mock';
import { Readable } from 'stream';
+import { loggerMock, type MockedLogger } from '@kbn/logging-mocks';
import { v4 as uuidv4 } from 'uuid';
import type {
SavedObjectsImportFailure,
@@ -40,8 +41,10 @@ import {
import type { ImportStateMap } from './lib';
describe('#importSavedObjectsFromStream', () => {
+ let logger: MockedLogger;
beforeEach(() => {
jest.clearAllMocks();
+ logger = loggerMock.create();
// mock empty output of each of these mocked modules so the import doesn't throw an error
mockCollectSavedObjects.mockResolvedValue({
errors: [],
@@ -72,7 +75,6 @@ describe('#importSavedObjectsFromStream', () => {
let savedObjectsClient: jest.Mocked;
let typeRegistry: jest.Mocked;
const namespace = 'some-namespace';
-
const setupOptions = ({
createNewCopies = false,
getTypeImpl = (type: string) =>
@@ -102,6 +104,7 @@ describe('#importSavedObjectsFromStream', () => {
createNewCopies,
importHooks,
managed,
+ log: logger,
};
};
const createObject = ({
diff --git a/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.ts b/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.ts
index 4182daa610b37..7d6bf9668286a 100644
--- a/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.ts
+++ b/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/import_saved_objects.ts
@@ -17,6 +17,7 @@ import type {
ISavedObjectTypeRegistry,
SavedObjectsImportHook,
} from '@kbn/core-saved-objects-server';
+import type { Logger } from '@kbn/logging';
import {
checkReferenceOrigins,
validateReferences,
@@ -59,6 +60,7 @@ export interface ImportSavedObjectsOptions {
* If provided, Kibana will apply the given option to the `managed` property.
*/
managed?: boolean;
+ log: Logger;
}
/**
@@ -79,7 +81,11 @@ export async function importSavedObjectsFromStream({
refresh,
compatibilityMode,
managed,
+ log,
}: ImportSavedObjectsOptions): Promise {
+ log.debug(
+ `Importing with overwrite ${overwrite ? 'enabled' : 'disabled'} and size limit ${objectLimit}`
+ );
let errorAccumulator: SavedObjectsImportFailure[] = [];
const supportedTypes = typeRegistry.getImportableAndExportableTypes().map((type) => type.name);
@@ -90,6 +96,11 @@ export async function importSavedObjectsFromStream({
supportedTypes,
managed,
});
+ log.debug(
+ `Importing types: ${[
+ ...new Set(collectSavedObjectsResult.collectedObjects.map((obj) => obj.type)),
+ ].join(', ')}`
+ );
errorAccumulator = [...errorAccumulator, ...collectSavedObjectsResult.errors];
// Map of all IDs for objects that we are attempting to import, and any references that are not included in the read stream;
// each value is empty by default
@@ -197,7 +208,17 @@ export async function importSavedObjectsFromStream({
objects: createSavedObjectsResult.createdObjects,
importHooks,
});
-
+ if (errorAccumulator.length > 0) {
+ log.error(
+ `Failed to import saved objects. ${errorAccumulator.length} errors: ${JSON.stringify(
+ errorAccumulator
+ )}`
+ );
+ } else {
+ log.info(
+ `Successfully imported ${createSavedObjectsResult.createdObjects.length} saved objects.`
+ );
+ }
return {
successCount: createSavedObjectsResult.createdObjects.length,
success: errorAccumulator.length === 0,
diff --git a/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/saved_objects_importer.ts b/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/saved_objects_importer.ts
index f990eb13c435b..e8c13180bbdaf 100644
--- a/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/saved_objects_importer.ts
+++ b/packages/core/saved-objects/core-saved-objects-import-export-server-internal/src/import/saved_objects_importer.ts
@@ -62,7 +62,6 @@ export class SavedObjectsImporter implements ISavedObjectsImporter {
compatibilityMode,
managed,
}: SavedObjectsImportOptions): Promise {
- this.#log.debug('Starting the import process');
return importSavedObjectsFromStream({
readStream,
createNewCopies,
@@ -75,6 +74,7 @@ export class SavedObjectsImporter implements ISavedObjectsImporter {
typeRegistry: this.#typeRegistry,
importHooks: this.#importHooks,
managed,
+ log: this.#log,
});
}
diff --git a/packages/kbn-esql-ast/src/builder/builder.ts b/packages/kbn-esql-ast/src/builder/builder.ts
index d033e177bd4b5..894ab99e5b3e8 100644
--- a/packages/kbn-esql-ast/src/builder/builder.ts
+++ b/packages/kbn-esql-ast/src/builder/builder.ts
@@ -18,10 +18,14 @@ import {
ESQLCommand,
ESQLCommandOption,
ESQLDecimalLiteral,
+ ESQLIdentifier,
ESQLInlineCast,
ESQLIntegerLiteral,
ESQLList,
ESQLLocation,
+ ESQLNamedParamLiteral,
+ ESQLParam,
+ ESQLPositionalParamLiteral,
ESQLOrderExpression,
ESQLSource,
} from '../types';
@@ -190,4 +194,65 @@ export namespace Builder {
};
}
}
+
+ export const identifier = (
+ template: AstNodeTemplate,
+ fromParser?: Partial
+ ): ESQLIdentifier => {
+ return {
+ ...template,
+ ...Builder.parserFields(fromParser),
+ type: 'identifier',
+ };
+ };
+
+ export namespace param {
+ export const unnamed = (fromParser?: Partial): ESQLParam => {
+ const node = {
+ ...Builder.parserFields(fromParser),
+ name: '',
+ value: '',
+ paramType: 'unnamed',
+ type: 'literal',
+ literalType: 'param',
+ };
+
+ return node as ESQLParam;
+ };
+
+ export const named = (
+ template: Omit, 'name' | 'literalType' | 'paramType'>,
+ fromParser?: Partial
+ ): ESQLNamedParamLiteral => {
+ const node: ESQLNamedParamLiteral = {
+ ...template,
+ ...Builder.parserFields(fromParser),
+ name: '',
+ type: 'literal',
+ literalType: 'param',
+ paramType: 'named',
+ };
+
+ return node;
+ };
+
+ export const positional = (
+ template: Omit<
+ AstNodeTemplate,
+ 'name' | 'literalType' | 'paramType'
+ >,
+ fromParser?: Partial
+ ): ESQLPositionalParamLiteral => {
+ const node: ESQLPositionalParamLiteral = {
+ ...template,
+ ...Builder.parserFields(fromParser),
+ name: '',
+ type: 'literal',
+ literalType: 'param',
+ paramType: 'positional',
+ };
+
+ return node;
+ };
+ }
}
diff --git a/packages/kbn-esql-ast/src/parser/__tests__/function.test.ts b/packages/kbn-esql-ast/src/parser/__tests__/function.test.ts
index 9d822f78f9333..d05ed36204b17 100644
--- a/packages/kbn-esql-ast/src/parser/__tests__/function.test.ts
+++ b/packages/kbn-esql-ast/src/parser/__tests__/function.test.ts
@@ -69,6 +69,103 @@ describe('function AST nodes', () => {
},
]);
});
+
+ it('parses out function name as identifier node', () => {
+ const query = 'ROW fn(1, 2, 3)';
+ const { ast, errors } = parse(query);
+
+ expect(errors.length).toBe(0);
+ expect(ast).toMatchObject([
+ {
+ type: 'command',
+ name: 'row',
+ args: [
+ {
+ type: 'function',
+ name: 'fn',
+ operator: {
+ type: 'identifier',
+ name: 'fn',
+ },
+ },
+ ],
+ },
+ ]);
+ });
+
+ it('parses out function name as named param', () => {
+ const query = 'ROW ?insert_here(1, 2, 3)';
+ const { ast, errors } = parse(query);
+
+ expect(errors.length).toBe(0);
+ expect(ast).toMatchObject([
+ {
+ type: 'command',
+ name: 'row',
+ args: [
+ {
+ type: 'function',
+ name: '?insert_here',
+ operator: {
+ type: 'literal',
+ literalType: 'param',
+ paramType: 'named',
+ value: 'insert_here',
+ },
+ },
+ ],
+ },
+ ]);
+ });
+
+ it('parses out function name as unnamed param', () => {
+ const query = 'ROW ?(1, 2, 3)';
+ const { ast, errors } = parse(query);
+
+ expect(errors.length).toBe(0);
+ expect(ast).toMatchObject([
+ {
+ type: 'command',
+ name: 'row',
+ args: [
+ {
+ type: 'function',
+ name: '?',
+ operator: {
+ type: 'literal',
+ literalType: 'param',
+ paramType: 'unnamed',
+ },
+ },
+ ],
+ },
+ ]);
+ });
+
+ it('parses out function name as positional param', () => {
+ const query = 'ROW ?30035(1, 2, 3)';
+ const { ast, errors } = parse(query);
+
+ expect(errors.length).toBe(0);
+ expect(ast).toMatchObject([
+ {
+ type: 'command',
+ name: 'row',
+ args: [
+ {
+ type: 'function',
+ name: '?30035',
+ operator: {
+ type: 'literal',
+ literalType: 'param',
+ paramType: 'positional',
+ value: 30035,
+ },
+ },
+ ],
+ },
+ ]);
+ });
});
describe('"unary-expression"', () => {
diff --git a/packages/kbn-esql-ast/src/parser/factories.ts b/packages/kbn-esql-ast/src/parser/factories.ts
index 246a62747ee6e..b575447f7e744 100644
--- a/packages/kbn-esql-ast/src/parser/factories.ts
+++ b/packages/kbn-esql-ast/src/parser/factories.ts
@@ -11,7 +11,13 @@
* In case of changes in the grammar, this script should be updated: esql_update_ast_script.js
*/
-import type { Token, ParserRuleContext, TerminalNode, RecognitionException } from 'antlr4';
+import type {
+ Token,
+ ParserRuleContext,
+ TerminalNode,
+ RecognitionException,
+ ParseTree,
+} from 'antlr4';
import {
IndexPatternContext,
QualifiedNameContext,
@@ -21,6 +27,10 @@ import {
type IntegerValueContext,
type QualifiedIntegerLiteralContext,
QualifiedNamePatternContext,
+ FunctionContext,
+ IdentifierContext,
+ InputParamContext,
+ InputNamedOrPositionalParamContext,
} from '../antlr/esql_parser';
import { DOUBLE_TICKS_REGEX, SINGLE_BACKTICK, TICKS_REGEX } from './constants';
import type {
@@ -42,6 +52,8 @@ import type {
ESQLNumericLiteral,
ESQLOrderExpression,
InlineCastingType,
+ ESQLFunctionCallExpression,
+ ESQLIdentifier,
} from '../types';
import { parseIdentifier, getPosition } from './helpers';
import { Builder, type AstNodeParserFields } from '../builder';
@@ -201,6 +213,60 @@ export function createFunction(
return node;
}
+export const createFunctionCall = (ctx: FunctionContext): ESQLFunctionCallExpression => {
+ const functionExpressionCtx = ctx.functionExpression();
+ const functionName = functionExpressionCtx.functionName();
+ const node: ESQLFunctionCallExpression = {
+ type: 'function',
+ subtype: 'variadic-call',
+ name: functionName.getText().toLowerCase(),
+ text: ctx.getText(),
+ location: getPosition(ctx.start, ctx.stop),
+ args: [],
+ incomplete: Boolean(ctx.exception),
+ };
+
+ const identifierOrParameter = functionName.identifierOrParameter();
+ if (identifierOrParameter) {
+ const identifier = identifierOrParameter.identifier();
+ if (identifier) {
+ node.operator = createIdentifier(identifier);
+ } else {
+ const parameter = identifierOrParameter.parameter();
+ if (parameter) {
+ node.operator = createParam(parameter);
+ }
+ }
+ }
+
+ return node;
+};
+
+const createIdentifier = (identifier: IdentifierContext): ESQLIdentifier => {
+ return Builder.identifier(
+ { name: identifier.getText().toLowerCase() },
+ createParserFields(identifier)
+ );
+};
+
+export const createParam = (ctx: ParseTree) => {
+ if (ctx instanceof InputParamContext) {
+ return Builder.param.unnamed(createParserFields(ctx));
+ } else if (ctx instanceof InputNamedOrPositionalParamContext) {
+ const text = ctx.getText();
+ const value = text.slice(1);
+ const valueAsNumber = Number(value);
+ const isPositional = String(valueAsNumber) === value;
+ const parserFields = createParserFields(ctx);
+
+ if (isPositional) {
+ return Builder.param.positional({ value: valueAsNumber }, parserFields);
+ } else {
+ return Builder.param.named({ value }, parserFields);
+ }
+ }
+};
+
export const createOrderExpression = (
ctx: ParserRuleContext,
arg: ESQLColumn,
diff --git a/packages/kbn-esql-ast/src/parser/walkers.ts b/packages/kbn-esql-ast/src/parser/walkers.ts
index 268c90417078b..60d69a17bb1c7 100644
--- a/packages/kbn-esql-ast/src/parser/walkers.ts
+++ b/packages/kbn-esql-ast/src/parser/walkers.ts
@@ -60,8 +60,6 @@ import {
type ValueExpressionContext,
ValueExpressionDefaultContext,
InlineCastContext,
- InputNamedOrPositionalParamContext,
- InputParamContext,
IndexPatternContext,
InlinestatsCommandContext,
} from '../antlr/esql_parser';
@@ -86,8 +84,9 @@ import {
createInlineCast,
createUnknownItem,
createOrderExpression,
+ createFunctionCall,
+ createParam,
} from './factories';
-import { getPosition } from './helpers';
import {
ESQLLiteral,
@@ -97,9 +96,6 @@ import {
ESQLAstItem,
ESQLAstField,
ESQLInlineCast,
- ESQLUnnamedParamLiteral,
- ESQLPositionalParamLiteral,
- ESQLNamedParamLiteral,
ESQLOrderExpression,
} from '../types';
import { firstItem, lastItem } from '../visitor/utils';
@@ -390,50 +386,8 @@ function getConstant(ctx: ConstantContext): ESQLAstItem {
const values: ESQLLiteral[] = [];
for (const child of ctx.children) {
- if (child instanceof InputParamContext) {
- const literal: ESQLUnnamedParamLiteral = {
- type: 'literal',
- literalType: 'param',
- paramType: 'unnamed',
- text: ctx.getText(),
- name: '',
- value: '',
- location: getPosition(ctx.start, ctx.stop),
- incomplete: Boolean(ctx.exception),
- };
- values.push(literal);
- } else if (child instanceof InputNamedOrPositionalParamContext) {
- const text = child.getText();
- const value = text.slice(1);
- const valueAsNumber = Number(value);
- const isPositional = String(valueAsNumber) === value;
-
- if (isPositional) {
- const literal: ESQLPositionalParamLiteral = {
- type: 'literal',
- literalType: 'param',
- paramType: 'positional',
- value: valueAsNumber,
- text,
- name: '',
- location: getPosition(ctx.start, ctx.stop),
- incomplete: Boolean(ctx.exception),
- };
- values.push(literal);
- } else {
- const literal: ESQLNamedParamLiteral = {
- type: 'literal',
- literalType: 'param',
- paramType: 'named',
- value,
- text,
- name: '',
- location: getPosition(ctx.start, ctx.stop),
- incomplete: Boolean(ctx.exception),
- };
- values.push(literal);
- }
- }
+ const param = createParam(child);
+ if (param) values.push(param);
}
return values;
@@ -478,15 +432,7 @@ export function visitPrimaryExpression(ctx: PrimaryExpressionContext): ESQLAstIt
}
if (ctx instanceof FunctionContext) {
const functionExpressionCtx = ctx.functionExpression();
- const functionNameContext = functionExpressionCtx.functionName().MATCH()
- ? functionExpressionCtx.functionName().MATCH()
- : functionExpressionCtx.functionName().identifierOrParameter();
- const fn = createFunction(
- functionNameContext.getText().toLowerCase(),
- ctx,
- undefined,
- 'variadic-call'
- );
+ const fn = createFunctionCall(ctx);
const asteriskArg = functionExpressionCtx.ASTERISK()
? createColumnStar(functionExpressionCtx.ASTERISK()!)
: undefined;
diff --git a/packages/kbn-esql-ast/src/types.ts b/packages/kbn-esql-ast/src/types.ts
index eabdefa5a401a..ea76fc3e0b9a4 100644
--- a/packages/kbn-esql-ast/src/types.ts
+++ b/packages/kbn-esql-ast/src/types.ts
@@ -26,6 +26,7 @@ export type ESQLSingleAstItem =
| ESQLTimeInterval
| ESQLList
| ESQLLiteral
+ | ESQLIdentifier
| ESQLCommandMode
| ESQLInlineCast
| ESQLOrderExpression
@@ -132,6 +133,11 @@ export interface ESQLFunction<
*/
subtype?: Subtype;
+ /**
+ * A node representing the function or operator being called.
+ */
+ operator?: ESQLIdentifier | ESQLParamLiteral;
+
args: ESQLAstItem[];
}
@@ -363,6 +369,10 @@ export interface ESQLNamedParamLiteral extends ESQLParamLiteral<'named'> {
value: string;
}
+export interface ESQLIdentifier extends ESQLAstBaseItem {
+ type: 'identifier';
+}
+
export const isESQLNamedParamLiteral = (node: ESQLAstItem): node is ESQLNamedParamLiteral =>
isESQLAstBaseItem(node) &&
(node as ESQLNamedParamLiteral).literalType === 'param' &&
@@ -376,6 +386,11 @@ export interface ESQLPositionalParamLiteral extends ESQLParamLiteral<'positional
value: number;
}
+export type ESQLParam =
+ | ESQLUnnamedParamLiteral
+ | ESQLNamedParamLiteral
+ | ESQLPositionalParamLiteral;
+
export interface ESQLMessage {
type: 'error' | 'warning';
text: string;
diff --git a/packages/kbn-optimizer/src/worker/webpack.config.ts b/packages/kbn-optimizer/src/worker/webpack.config.ts
index 96a17a6ae7229..b5da9566878e1 100644
--- a/packages/kbn-optimizer/src/worker/webpack.config.ts
+++ b/packages/kbn-optimizer/src/worker/webpack.config.ts
@@ -280,6 +280,14 @@ export function getWebpackConfig(
plugins: ['@babel/plugin-transform-logical-assignment-operators'],
},
},
+ {
+ test: /node_modules[\/\\]launchdarkly[^\/\\]+[\/\\].*.js$/,
+ loaders: 'babel-loader',
+ options: {
+ envName: worker.dist ? 'production' : 'development',
+ presets: [BABEL_PRESET],
+ },
+ },
{
test: /\.(html|md|txt|tmpl)$/,
use: {
diff --git a/src/core/server/integration_tests/saved_objects/routes/import.test.ts b/src/core/server/integration_tests/saved_objects/routes/import.test.ts
index 917f7f1642e8c..bf1fae4967e95 100644
--- a/src/core/server/integration_tests/saved_objects/routes/import.test.ts
+++ b/src/core/server/integration_tests/saved_objects/routes/import.test.ts
@@ -13,7 +13,6 @@ import supertest from 'supertest';
import { SavedObjectsErrorHelpers } from '@kbn/core-saved-objects-server';
import { savedObjectsClientMock } from '@kbn/core-saved-objects-api-server-mocks';
import type { ICoreUsageStatsClient } from '@kbn/core-usage-data-base-server-internal';
-import type { Logger, LogLevelId } from '@kbn/logging';
import {
coreUsageStatsClientMock,
coreUsageDataServiceMock,
@@ -28,6 +27,7 @@ import {
type InternalSavedObjectsRequestHandlerContext,
} from '@kbn/core-saved-objects-server-internal';
import { setupServer, createExportableType } from '@kbn/core-test-helpers-test-utils';
+import { loggerMock, type MockedLogger } from '@kbn/logging-mocks';
type SetupServerReturn = Awaited>;
@@ -41,6 +41,7 @@ describe(`POST ${URL}`, () => {
let httpSetup: SetupServerReturn['httpSetup'];
let handlerContext: SetupServerReturn['handlerContext'];
let savedObjectsClient: ReturnType;
+ let mockLogger: MockedLogger;
const emptyResponse = { saved_objects: [], total: 0, per_page: 0, page: 0 };
const mockIndexPattern = {
@@ -57,20 +58,10 @@ describe(`POST ${URL}`, () => {
references: [],
managed: false,
};
- const mockLogger: jest.Mocked = {
- debug: jest.fn(),
- info: jest.fn(),
- error: jest.fn(),
- warn: jest.fn(),
- trace: jest.fn(),
- fatal: jest.fn(),
- log: jest.fn(),
- isLevelEnabled: jest.fn((level: LogLevelId) => true),
- get: jest.fn(() => mockLogger),
- };
beforeEach(async () => {
({ server, httpSetup, handlerContext } = await setupServer());
+ mockLogger = loggerMock.create();
handlerContext.savedObjects.typeRegistry.getImportableAndExportableTypes.mockReturnValue(
allowedTypes.map(createExportableType)
);
diff --git a/src/dev/build/tasks/os_packages/docker_generator/run.ts b/src/dev/build/tasks/os_packages/docker_generator/run.ts
index c810a74091458..85cd6d7458ba9 100644
--- a/src/dev/build/tasks/os_packages/docker_generator/run.ts
+++ b/src/dev/build/tasks/os_packages/docker_generator/run.ts
@@ -51,7 +51,7 @@ export async function runDockerGenerator(
*/
if (flags.baseImage === 'wolfi')
baseImageName =
- 'docker.elastic.co/wolfi/chainguard-base:latest@sha256:8cff240b81057968575dd28dab0c3609657cb7e0e60ff017261e5b721fad9e1b';
+ 'docker.elastic.co/wolfi/chainguard-base:latest@sha256:7082adcc2c4380be273ab5b80c4a762b4f17279c13c6fc8f87a60190aee2e2cd';
let imageFlavor = '';
if (flags.baseImage === 'ubi') imageFlavor += `-ubi`;
diff --git a/src/plugins/dashboard/kibana.jsonc b/src/plugins/dashboard/kibana.jsonc
index c84d4a9dc293d..9d47ab95c8872 100644
--- a/src/plugins/dashboard/kibana.jsonc
+++ b/src/plugins/dashboard/kibana.jsonc
@@ -16,6 +16,7 @@
"dataViews",
"dataViewEditor",
"embeddable",
+ "fieldFormats",
"controls",
"inspector",
"navigation",
diff --git a/test/api_integration/apis/home/sample_data.ts b/test/api_integration/apis/home/sample_data.ts
index d290f772fdec5..13ab83e85a05a 100644
--- a/test/api_integration/apis/home/sample_data.ts
+++ b/test/api_integration/apis/home/sample_data.ts
@@ -24,12 +24,6 @@ export default function ({ getService }: FtrProviderContext) {
* @see {@link src/plugins/home/server/services/sample_data/data_sets/flights/index.ts}
*/
const FLIGHTS_OVERVIEW_DASHBOARD_ID = '7adfa750-4c81-11e8-b3d7-01146121b73d';
- const FLIGHTS_CANVAS_APPLINK_PATH =
- '/app/canvas#/workpad/workpad-a474e74b-aedc-47c3-894a-db77e62c41e0'; // includes default ID of the flights canvas applink path
-
- const includesPathInAppLinks = (appLinks: Array<{ path: string }>, path: string): boolean => {
- return appLinks.some((item) => item.path === path);
- };
describe('sample data apis', () => {
before(async () => {
@@ -52,12 +46,7 @@ export default function ({ getService }: FtrProviderContext) {
const flightsData = findFlightsData(resp);
expect(flightsData.status).to.be('not_installed');
- // Check and make sure the sample dataset reflects the default object IDs, because no sample data objects exist.
- // Instead of checking each object ID, we check the dashboard and canvas app link as representatives.
expect(flightsData.overviewDashboard).to.be(FLIGHTS_OVERVIEW_DASHBOARD_ID);
- expect(includesPathInAppLinks(flightsData.appLinks, FLIGHTS_CANVAS_APPLINK_PATH)).to.be(
- true
- );
});
});
@@ -79,7 +68,7 @@ export default function ({ getService }: FtrProviderContext) {
expect(resp.body).to.eql({
elasticsearchIndicesCreated: { kibana_sample_data_flights: 13014 },
- kibanaSavedObjectsLoaded: 8,
+ kibanaSavedObjectsLoaded: 7,
});
});
@@ -136,19 +125,11 @@ export default function ({ getService }: FtrProviderContext) {
const flightsData = findFlightsData(resp);
expect(flightsData.status).to.be('installed');
- // Check and make sure the sample dataset reflects the existing object IDs in each space.
- // Instead of checking each object ID, we check the dashboard and canvas app link as representatives.
if (space === 'default') {
expect(flightsData.overviewDashboard).to.be(FLIGHTS_OVERVIEW_DASHBOARD_ID);
- expect(includesPathInAppLinks(flightsData.appLinks, FLIGHTS_CANVAS_APPLINK_PATH)).to.be(
- true
- );
} else {
// the sample data objects installed in the 'other' space had their IDs regenerated upon import
expect(flightsData.overviewDashboard).not.to.be(FLIGHTS_OVERVIEW_DASHBOARD_ID);
- expect(includesPathInAppLinks(flightsData.appLinks, FLIGHTS_CANVAS_APPLINK_PATH)).to.be(
- false
- );
}
});
});
@@ -186,12 +167,7 @@ export default function ({ getService }: FtrProviderContext) {
const flightsData = findFlightsData(resp);
expect(flightsData.status).to.be('not_installed');
- // Check and make sure the sample dataset reflects the default object IDs, because no sample data objects exist.
- // Instead of checking each object ID, we check the dashboard and canvas app link as representatives.
expect(flightsData.overviewDashboard).to.be(FLIGHTS_OVERVIEW_DASHBOARD_ID);
- expect(includesPathInAppLinks(flightsData.appLinks, FLIGHTS_CANVAS_APPLINK_PATH)).to.be(
- true
- );
});
});
}
diff --git a/test/functional/apps/console/_misc_console_behavior.ts b/test/functional/apps/console/_misc_console_behavior.ts
index fc53b6b37fb51..4185a2198fa32 100644
--- a/test/functional/apps/console/_misc_console_behavior.ts
+++ b/test/functional/apps/console/_misc_console_behavior.ts
@@ -154,8 +154,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) {
await PageObjects.console.openConsole();
});
- // Failing: See https://github.com/elastic/kibana/issues/193868
- describe.skip('customizable font size', () => {
+ describe('customizable font size', () => {
it('should allow the font size to be customized', async () => {
await PageObjects.console.openConfig();
await PageObjects.console.setFontSizeSetting(20);
diff --git a/test/functional/page_objects/console_page.ts b/test/functional/page_objects/console_page.ts
index 29b88787e7ec2..71a4d05aecdb0 100644
--- a/test/functional/page_objects/console_page.ts
+++ b/test/functional/page_objects/console_page.ts
@@ -9,6 +9,7 @@
import { Key } from 'selenium-webdriver';
import { asyncForEach } from '@kbn/std';
+import expect from '@kbn/expect';
import { FtrService } from '../ftr_provider_context';
export class ConsolePageObject extends FtrService {
@@ -368,10 +369,12 @@ export class ConsolePageObject extends FtrService {
public async setFontSizeSetting(newSize: number) {
// while the settings form opens/loads this may fail, so retry for a while
await this.retry.try(async () => {
+ const newSizeString = String(newSize);
const fontSizeInput = await this.testSubjects.find('setting-font-size-input');
await fontSizeInput.clearValue({ withJS: true });
await fontSizeInput.click();
- await fontSizeInput.type(String(newSize));
+ await fontSizeInput.type(newSizeString);
+ expect(await fontSizeInput.getAttribute('value')).to.be(newSizeString);
});
}
diff --git a/x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx b/x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx
index 1343f5ed9a4bb..320beb1ca6b05 100644
--- a/x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx
+++ b/x-pack/packages/kbn-ai-assistant/src/chat/chat_flyout.tsx
@@ -47,6 +47,7 @@ export function ChatFlyout({
isOpen,
onClose,
navigateToConversation,
+ hideConversationList,
}: {
initialTitle: string;
initialMessages: Message[];
@@ -54,6 +55,7 @@ export function ChatFlyout({
isOpen: boolean;
onClose: () => void;
navigateToConversation?: (conversationId?: string) => void;
+ hideConversationList?: boolean;
}) {
const { euiTheme } = useEuiTheme();
const breakpoint = useCurrentEuiBreakpoint();
@@ -174,84 +176,86 @@ export function ChatFlyout({
}}
>
-
-
- setConversationsExpanded(!conversationsExpanded)}
- />
-
- }
- />
-
- {conversationsExpanded ? (
- {
- conversationList.deleteConversation(deletedConversationId).then(() => {
- if (deletedConversationId === conversationId) {
- setConversationId(undefined);
- }
- });
- }}
- onConversationSelect={(nextConversationId) => {
- setConversationId(nextConversationId);
- }}
- />
- ) : (
+ {!hideConversationList ? (
+
- {
- setConversationId(undefined);
- }}
+ className={expandButtonClassName}
+ color="text"
+ data-test-subj="observabilityAiAssistantChatFlyoutButton"
+ iconType={conversationsExpanded ? 'transitionLeftIn' : 'transitionLeftOut'}
+ onClick={() => setConversationsExpanded(!conversationsExpanded)}
/>
}
- className={newChatButtonClassName}
/>
- )}
-
+
+ {conversationsExpanded ? (
+ {
+ conversationList.deleteConversation(deletedConversationId).then(() => {
+ if (deletedConversationId === conversationId) {
+ setConversationId(undefined);
+ }
+ });
+ }}
+ onConversationSelect={(nextConversationId) => {
+ setConversationId(nextConversationId);
+ }}
+ />
+ ) : (
+
+ {
+ setConversationId(undefined);
+ }}
+ />
+
+ }
+ className={newChatButtonClassName}
+ />
+ )}
+
+ ) : null}
{
const actual = jest.requireActual('@kbn/core-saved-objects-utils-server');
@@ -588,6 +589,9 @@ describe('create()', () => {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: DEFAULT_USAGE_API_URL,
+ },
});
const localActionTypeRegistryParams = {
diff --git a/x-pack/plugins/actions/server/actions_config.test.ts b/x-pack/plugins/actions/server/actions_config.test.ts
index a6966e0e85c40..2b5c4efc283b6 100644
--- a/x-pack/plugins/actions/server/actions_config.test.ts
+++ b/x-pack/plugins/actions/server/actions_config.test.ts
@@ -6,7 +6,7 @@
*/
import { ByteSizeValue } from '@kbn/config-schema';
-import { ActionsConfig } from './config';
+import { ActionsConfig, DEFAULT_USAGE_API_URL } from './config';
import {
DEFAULT_MICROSOFT_EXCHANGE_URL,
DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
@@ -42,6 +42,9 @@ const defaultActionsConfig: ActionsConfig = {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: DEFAULT_USAGE_API_URL,
+ },
};
describe('ensureUriAllowed', () => {
diff --git a/x-pack/plugins/actions/server/config.test.ts b/x-pack/plugins/actions/server/config.test.ts
index 5adc9c18b07a7..4034fc5cb50b5 100644
--- a/x-pack/plugins/actions/server/config.test.ts
+++ b/x-pack/plugins/actions/server/config.test.ts
@@ -38,6 +38,9 @@ describe('config validation', () => {
"proxyRejectUnauthorizedCertificates": true,
"rejectUnauthorized": true,
"responseTimeout": "PT1M",
+ "usage": Object {
+ "url": "https://usage-api.usage-api/api/v1/usage",
+ },
}
`);
});
@@ -85,6 +88,9 @@ describe('config validation', () => {
"proxyRejectUnauthorizedCertificates": false,
"rejectUnauthorized": false,
"responseTimeout": "PT1M",
+ "usage": Object {
+ "url": "https://usage-api.usage-api/api/v1/usage",
+ },
}
`);
});
@@ -225,6 +231,9 @@ describe('config validation', () => {
"proxyVerificationMode": "none",
"verificationMode": "none",
},
+ "usage": Object {
+ "url": "https://usage-api.usage-api/api/v1/usage",
+ },
}
`);
});
diff --git a/x-pack/plugins/actions/server/config.ts b/x-pack/plugins/actions/server/config.ts
index d806bde1fa227..f475c05424df4 100644
--- a/x-pack/plugins/actions/server/config.ts
+++ b/x-pack/plugins/actions/server/config.ts
@@ -72,6 +72,8 @@ const connectorTypeSchema = schema.object({
maxAttempts: schema.maybe(schema.number({ min: MIN_MAX_ATTEMPTS, max: MAX_MAX_ATTEMPTS })),
});
+export const DEFAULT_USAGE_API_URL = 'https://usage-api.usage-api/api/v1/usage';
+
// We leverage enabledActionTypes list by allowing the other plugins to overwrite it by using "setEnabledConnectorTypes" in the plugin setup.
// The list can be overwritten only if it's not already been set in the config.
const enabledConnectorTypesSchema = schema.arrayOf(
@@ -145,15 +147,14 @@ export const configSchema = schema.object({
max: schema.maybe(schema.number({ min: MIN_QUEUED_MAX, defaultValue: DEFAULT_QUEUED_MAX })),
})
),
- usage: schema.maybe(
- schema.object({
- ca: schema.maybe(
- schema.object({
- path: schema.string(),
- })
- ),
- })
- ),
+ usage: schema.object({
+ url: schema.string({ defaultValue: DEFAULT_USAGE_API_URL }),
+ ca: schema.maybe(
+ schema.object({
+ path: schema.string(),
+ })
+ ),
+ }),
});
export type ActionsConfig = TypeOf;
diff --git a/x-pack/plugins/actions/server/integration_tests/axios_utils_connection.test.ts b/x-pack/plugins/actions/server/integration_tests/axios_utils_connection.test.ts
index 200656d339ac3..3a4101bb9f152 100644
--- a/x-pack/plugins/actions/server/integration_tests/axios_utils_connection.test.ts
+++ b/x-pack/plugins/actions/server/integration_tests/axios_utils_connection.test.ts
@@ -20,7 +20,7 @@ import { ByteSizeValue } from '@kbn/config-schema';
import { Logger } from '@kbn/core/server';
import { loggingSystemMock } from '@kbn/core/server/mocks';
import { createReadySignal } from '@kbn/event-log-plugin/server/lib/ready_signal';
-import { ActionsConfig } from '../config';
+import { ActionsConfig, DEFAULT_USAGE_API_URL } from '../config';
import { ActionsConfigurationUtilities, getActionsConfigurationUtilities } from '../actions_config';
import { resolveCustomHosts } from '../lib/custom_host_settings';
import {
@@ -691,6 +691,9 @@ const BaseActionsConfig: ActionsConfig = {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: DEFAULT_USAGE_API_URL,
+ },
};
function getACUfromConfig(config: Partial = {}): ActionsConfigurationUtilities {
diff --git a/x-pack/plugins/actions/server/integration_tests/axios_utils_proxy.test.ts b/x-pack/plugins/actions/server/integration_tests/axios_utils_proxy.test.ts
index f29b2a9855186..1c1d411111253 100644
--- a/x-pack/plugins/actions/server/integration_tests/axios_utils_proxy.test.ts
+++ b/x-pack/plugins/actions/server/integration_tests/axios_utils_proxy.test.ts
@@ -20,7 +20,7 @@ import { ByteSizeValue } from '@kbn/config-schema';
import { Logger } from '@kbn/core/server';
import { loggingSystemMock } from '@kbn/core/server/mocks';
import { createReadySignal } from '@kbn/event-log-plugin/server/lib/ready_signal';
-import { ActionsConfig } from '../config';
+import { ActionsConfig, DEFAULT_USAGE_API_URL } from '../config';
import { ActionsConfigurationUtilities, getActionsConfigurationUtilities } from '../actions_config';
import { resolveCustomHosts } from '../lib/custom_host_settings';
import {
@@ -597,6 +597,9 @@ const BaseActionsConfig: ActionsConfig = {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: DEFAULT_USAGE_API_URL,
+ },
};
function getACUfromConfig(config: Partial = {}): ActionsConfigurationUtilities {
diff --git a/x-pack/plugins/actions/server/lib/custom_host_settings.test.ts b/x-pack/plugins/actions/server/lib/custom_host_settings.test.ts
index 818d7fb9bcd0a..0a9d9c6df31e7 100644
--- a/x-pack/plugins/actions/server/lib/custom_host_settings.test.ts
+++ b/x-pack/plugins/actions/server/lib/custom_host_settings.test.ts
@@ -10,7 +10,7 @@ import { resolve as pathResolve, join as pathJoin } from 'path';
import { ByteSizeValue } from '@kbn/config-schema';
import moment from 'moment';
-import { ActionsConfig } from '../config';
+import { ActionsConfig, DEFAULT_USAGE_API_URL } from '../config';
import { Logger } from '@kbn/core/server';
import { loggingSystemMock } from '@kbn/core/server/mocks';
@@ -82,6 +82,9 @@ describe('custom_host_settings', () => {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: DEFAULT_USAGE_API_URL,
+ },
};
test('ensure it copies over the config parts that it does not touch', () => {
diff --git a/x-pack/plugins/actions/server/plugin.test.ts b/x-pack/plugins/actions/server/plugin.test.ts
index 89efb80867fd7..4ff87aa0459ef 100644
--- a/x-pack/plugins/actions/server/plugin.test.ts
+++ b/x-pack/plugins/actions/server/plugin.test.ts
@@ -30,6 +30,7 @@ import {
DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
DEFAULT_MICROSOFT_GRAPH_API_URL,
} from '../common';
+import { cloudMock } from '@kbn/cloud-plugin/server/mocks';
const executor: ExecutorType<{}, {}, {}, void> = async (options) => {
return { status: 'ok', actionId: options.actionId };
@@ -59,6 +60,9 @@ function getConfig(overrides = {}) {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: 'ca.path',
+ },
...overrides,
};
}
@@ -84,6 +88,9 @@ describe('Actions Plugin', () => {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: 'ca.path',
+ },
});
plugin = new ActionsPlugin(context);
coreSetup = coreMock.createSetup();
@@ -95,6 +102,7 @@ describe('Actions Plugin', () => {
eventLog: eventLogMock.createSetup(),
usageCollection: usageCollectionPluginMock.createSetupContract(),
features: featuresPluginMock.createSetup(),
+ cloud: cloudMock.createSetup(),
};
coreSetup.getStartServices.mockResolvedValue([
coreMock.createStart(),
@@ -347,6 +355,7 @@ describe('Actions Plugin', () => {
eventLog: eventLogMock.createSetup(),
usageCollection: usageCollectionPluginMock.createSetupContract(),
features: featuresPluginMock.createSetup(),
+ cloud: cloudMock.createSetup(),
};
}
@@ -374,6 +383,7 @@ describe('Actions Plugin', () => {
usageCollection: usageCollectionPluginMock.createSetupContract(),
features: featuresPluginMock.createSetup(),
serverless: serverlessPluginMock.createSetupContract(),
+ cloud: cloudMock.createSetup(),
};
}
@@ -585,6 +595,9 @@ describe('Actions Plugin', () => {
microsoftGraphApiUrl: DEFAULT_MICROSOFT_GRAPH_API_URL,
microsoftGraphApiScope: DEFAULT_MICROSOFT_GRAPH_API_SCOPE,
microsoftExchangeUrl: DEFAULT_MICROSOFT_EXCHANGE_URL,
+ usage: {
+ url: 'ca.path',
+ },
});
plugin = new ActionsPlugin(context);
coreSetup = coreMock.createSetup();
@@ -596,6 +609,7 @@ describe('Actions Plugin', () => {
eventLog: eventLogMock.createSetup(),
usageCollection: usageCollectionPluginMock.createSetupContract(),
features: featuresPluginMock.createSetup(),
+ cloud: cloudMock.createSetup(),
};
pluginsStart = {
licensing: licensingMock.createStart(),
@@ -680,6 +694,7 @@ describe('Actions Plugin', () => {
eventLog: eventLogMock.createSetup(),
usageCollection: usageCollectionPluginMock.createSetupContract(),
features: featuresPluginMock.createSetup(),
+ cloud: cloudMock.createSetup(),
};
pluginsStart = {
licensing: licensingMock.createStart(),
diff --git a/x-pack/plugins/actions/server/plugin.ts b/x-pack/plugins/actions/server/plugin.ts
index 36fc4b68d443c..57304c176c13d 100644
--- a/x-pack/plugins/actions/server/plugin.ts
+++ b/x-pack/plugins/actions/server/plugin.ts
@@ -42,6 +42,7 @@ import {
import { MonitoringCollectionSetup } from '@kbn/monitoring-collection-plugin/server';
import { ServerlessPluginSetup, ServerlessPluginStart } from '@kbn/serverless/server';
+import type { CloudSetup } from '@kbn/cloud-plugin/server';
import { ActionsConfig, AllowedHosts, EnabledConnectorTypes, getValidatedConfig } from './config';
import { resolveCustomHosts } from './lib/custom_host_settings';
import { events } from './lib/event_based_telemetry';
@@ -108,6 +109,7 @@ import type { IUnsecuredActionsClient } from './unsecured_actions_client/unsecur
import { UnsecuredActionsClient } from './unsecured_actions_client/unsecured_actions_client';
import { createBulkUnsecuredExecutionEnqueuerFunction } from './create_unsecured_execute_function';
import { createSystemConnectors } from './create_system_actions';
+import { ConnectorUsageReportingTask } from './usage/connector_usage_reporting_task';
export interface PluginSetupContract {
registerType<
@@ -180,6 +182,7 @@ export interface ActionsPluginsSetup {
spaces?: SpacesPluginSetup;
monitoringCollection?: MonitoringCollectionSetup;
serverless?: ServerlessPluginSetup;
+ cloud: CloudSetup;
}
export interface ActionsPluginsStart {
@@ -214,6 +217,7 @@ export class ActionsPlugin implements Plugin {});
+
return {
isActionTypeEnabled: (id, options = { notifyUsage: false }) => {
return this.actionTypeRegistry!.isActionTypeEnabled(id, options);
diff --git a/x-pack/plugins/actions/server/usage/connector_usage_reporting_task.test.ts b/x-pack/plugins/actions/server/usage/connector_usage_reporting_task.test.ts
new file mode 100644
index 0000000000000..77dec7f15e156
--- /dev/null
+++ b/x-pack/plugins/actions/server/usage/connector_usage_reporting_task.test.ts
@@ -0,0 +1,394 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import fs from 'fs';
+import axios from 'axios';
+import { loggingSystemMock } from '@kbn/core/server/mocks';
+import { coreMock } from '@kbn/core/server/mocks';
+import {
+ TaskManagerSetupContract,
+ TaskManagerStartContract,
+ TaskStatus,
+} from '@kbn/task-manager-plugin/server';
+import { taskManagerMock } from '@kbn/task-manager-plugin/server/mocks';
+import {
+ CONNECTOR_USAGE_REPORTING_SOURCE_ID,
+ CONNECTOR_USAGE_REPORTING_TASK_ID,
+ CONNECTOR_USAGE_REPORTING_TASK_SCHEDULE,
+ CONNECTOR_USAGE_REPORTING_TASK_TYPE,
+ ConnectorUsageReportingTask,
+} from './connector_usage_reporting_task';
+import type { CoreSetup, ElasticsearchClient } from '@kbn/core/server';
+import { ActionsPluginsStart } from '../plugin';
+import { SearchResponse } from '@elastic/elasticsearch/lib/api/types';
+
+jest.mock('axios');
+const mockedAxiosPost = jest.spyOn(axios, 'post');
+
+const nowStr = '2024-01-01T12:00:00.000Z';
+const nowDate = new Date(nowStr);
+
+jest.useFakeTimers();
+jest.setSystemTime(nowDate.getTime());
+const readFileSpy = jest.spyOn(fs, 'readFileSync');
+
+describe('ConnectorUsageReportingTask', () => {
+ const logger = loggingSystemMock.createLogger();
+ const { createSetup } = coreMock;
+ const { createSetup: taskManagerSetupMock, createStart: taskManagerStartMock } = taskManagerMock;
+ let mockEsClient: jest.Mocked;
+ let mockCore: CoreSetup;
+ let mockTaskManagerSetup: jest.Mocked;
+ let mockTaskManagerStart: jest.Mocked;
+
+ beforeEach(async () => {
+ mockTaskManagerSetup = taskManagerSetupMock();
+ mockTaskManagerStart = taskManagerStartMock();
+ mockCore = createSetup();
+ mockEsClient = (await mockCore.getStartServices())[0].elasticsearch.client
+ .asInternalUser as jest.Mocked;
+ });
+
+ afterEach(() => {
+ jest.resetAllMocks();
+ });
+
+ const createTaskRunner = async ({
+ lastReportedUsageDate,
+ projectId,
+ attempts = 0,
+ }: {
+ lastReportedUsageDate: Date;
+ projectId?: string;
+ attempts?: number;
+ }) => {
+ const timestamp = new Date(new Date().setMinutes(-15));
+ const task = new ConnectorUsageReportingTask({
+ eventLogIndex: 'test-index',
+ projectId,
+ logger,
+ core: mockCore,
+ taskManager: mockTaskManagerSetup,
+ config: {
+ url: 'usage-api',
+ ca: {
+ path: './ca.crt',
+ },
+ },
+ });
+
+ await task.start(mockTaskManagerStart);
+
+ const createTaskRunnerFunction =
+ mockTaskManagerSetup.registerTaskDefinitions.mock.calls[0][0][
+ CONNECTOR_USAGE_REPORTING_TASK_TYPE
+ ].createTaskRunner;
+
+ return createTaskRunnerFunction({
+ taskInstance: {
+ id: CONNECTOR_USAGE_REPORTING_TASK_ID,
+ runAt: timestamp,
+ attempts: 0,
+ ownerId: '',
+ status: TaskStatus.Running,
+ startedAt: timestamp,
+ scheduledAt: timestamp,
+ retryAt: null,
+ params: {},
+ state: {
+ lastReportedUsageDate,
+ attempts,
+ },
+ taskType: CONNECTOR_USAGE_REPORTING_TASK_TYPE,
+ },
+ });
+ };
+
+ it('registers the task', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ new ConnectorUsageReportingTask({
+ eventLogIndex: 'test-index',
+ projectId: 'test-projecr',
+ logger,
+ core: createSetup(),
+ taskManager: mockTaskManagerSetup,
+ config: {
+ url: 'usage-api',
+ ca: {
+ path: './ca.crt',
+ },
+ },
+ });
+
+ expect(mockTaskManagerSetup.registerTaskDefinitions).toBeCalledTimes(1);
+ expect(mockTaskManagerSetup.registerTaskDefinitions).toHaveBeenCalledWith({
+ [CONNECTOR_USAGE_REPORTING_TASK_TYPE]: {
+ title: 'Connector usage reporting task',
+ timeout: '1m',
+ createTaskRunner: expect.any(Function),
+ },
+ });
+ });
+
+ it('schedules the task', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ const core = createSetup();
+ const taskManagerStart = taskManagerStartMock();
+
+ const task = new ConnectorUsageReportingTask({
+ eventLogIndex: 'test-index',
+ projectId: 'test-projecr',
+ logger,
+ core,
+ taskManager: mockTaskManagerSetup,
+ config: {
+ url: 'usage-api',
+ ca: {
+ path: './ca.crt',
+ },
+ },
+ });
+
+ await task.start(taskManagerStart);
+
+ expect(taskManagerStart.ensureScheduled).toBeCalledTimes(1);
+ expect(taskManagerStart.ensureScheduled).toHaveBeenCalledWith({
+ id: CONNECTOR_USAGE_REPORTING_TASK_ID,
+ taskType: CONNECTOR_USAGE_REPORTING_TASK_TYPE,
+ schedule: {
+ ...CONNECTOR_USAGE_REPORTING_TASK_SCHEDULE,
+ },
+ state: {},
+ params: {},
+ });
+ });
+
+ it('logs error if task manager is not ready', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ const core = createSetup();
+ const taskManagerStart = taskManagerStartMock();
+
+ const task = new ConnectorUsageReportingTask({
+ eventLogIndex: 'test-index',
+ projectId: 'test-projecr',
+ logger,
+ core,
+ taskManager: mockTaskManagerSetup,
+ config: {
+ url: 'usage-api',
+ ca: {
+ path: './ca.crt',
+ },
+ },
+ });
+
+ await task.start();
+
+ expect(taskManagerStart.ensureScheduled).not.toBeCalled();
+ expect(logger.error).toHaveBeenCalledWith(
+ `Missing required task manager service during start of ${CONNECTOR_USAGE_REPORTING_TASK_TYPE}`
+ );
+ });
+
+ it('logs error if scheduling task fails', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ const core = createSetup();
+ const taskManagerStart = taskManagerStartMock();
+ taskManagerStart.ensureScheduled.mockRejectedValue(new Error('test'));
+
+ const task = new ConnectorUsageReportingTask({
+ eventLogIndex: 'test-index',
+ projectId: 'test-projecr',
+ logger,
+ core,
+ taskManager: mockTaskManagerSetup,
+ config: {
+ url: 'usage-api',
+ ca: {
+ path: './ca.crt',
+ },
+ },
+ });
+
+ await task.start(taskManagerStart);
+
+ expect(logger.error).toHaveBeenCalledWith(
+ 'Error scheduling task actions:connector_usage_reporting, received test'
+ );
+ });
+
+ it('returns the existing state and logs a warning when project id is missing', async () => {
+ const lastReportedUsageDateStr = '2024-01-01T00:00:00.000Z';
+ const lastReportedUsageDate = new Date(lastReportedUsageDateStr);
+
+ const taskRunner = await createTaskRunner({ lastReportedUsageDate });
+
+ const response = await taskRunner.run();
+
+ expect(logger.warn).toHaveBeenCalledWith(
+ 'Missing required project id while running actions:connector_usage_reporting'
+ );
+
+ expect(response).toEqual({
+ state: {
+ attempts: 0,
+ lastReportedUsageDate,
+ },
+ });
+ });
+
+ it('returns the existing state and logs an error when the CA Certificate is missing', async () => {
+ const lastReportedUsageDateStr = '2024-01-01T00:00:00.000Z';
+ const lastReportedUsageDate = new Date(lastReportedUsageDateStr);
+ readFileSpy.mockImplementationOnce((func) => {
+ throw new Error('Mock file read error.');
+ });
+
+ const taskRunner = await createTaskRunner({ lastReportedUsageDate, projectId: 'test-id' });
+
+ const response = await taskRunner.run();
+
+ expect(logger.error).toHaveBeenCalledTimes(2);
+
+ expect(logger.error).toHaveBeenNthCalledWith(
+ 1,
+ `CA Certificate for the project "test-id" couldn't be loaded, Error: Mock file read error.`
+ );
+
+ expect(logger.error).toHaveBeenNthCalledWith(
+ 2,
+ 'Missing required CA Certificate while running actions:connector_usage_reporting'
+ );
+
+ expect(response).toEqual({
+ state: {
+ attempts: 0,
+ lastReportedUsageDate,
+ },
+ });
+ });
+
+ it('runs the task', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ mockEsClient.search.mockResolvedValueOnce({
+ aggregations: { total_usage: 215 },
+ } as SearchResponse);
+
+ mockedAxiosPost.mockResolvedValueOnce(200);
+
+ const lastReportedUsageDateStr = '2024-01-01T00:00:00.000Z';
+ const lastReportedUsageDate = new Date(lastReportedUsageDateStr);
+
+ const taskRunner = await createTaskRunner({ lastReportedUsageDate, projectId: 'test-project' });
+
+ const response = await taskRunner.run();
+
+ const report = [
+ {
+ creation_timestamp: nowStr,
+ id: 'connector-request-body-bytes-test-project-2024-01-01T12:00:00.000Z',
+ source: {
+ id: CONNECTOR_USAGE_REPORTING_SOURCE_ID,
+ instance_group_id: 'test-project',
+ },
+ usage: {
+ period_seconds: 43200,
+ quantity: 0,
+ type: 'connector_request_body_bytes',
+ },
+ usage_timestamp: nowStr,
+ },
+ ];
+
+ expect(mockedAxiosPost).toHaveBeenCalledWith('usage-api', report, {
+ headers: { 'Content-Type': 'application/json' },
+ timeout: 30000,
+ httpsAgent: expect.any(Object),
+ });
+
+ expect(response).toEqual({
+ state: {
+ attempts: 0,
+ lastReportedUsageDate: expect.any(Date),
+ },
+ });
+ });
+
+ it('re-runs the task when search for records fails', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ mockEsClient.search.mockRejectedValue(new Error('500'));
+
+ mockedAxiosPost.mockResolvedValueOnce(200);
+
+ const lastReportedUsageDate = new Date('2024-01-01T00:00:00.000Z');
+
+ const taskRunner = await createTaskRunner({ lastReportedUsageDate, projectId: 'test-project' });
+
+ const response = await taskRunner.run();
+
+ expect(response).toEqual({
+ state: {
+ lastReportedUsageDate,
+ attempts: 0,
+ },
+ runAt: nowDate,
+ });
+ });
+
+ it('re-runs the task when it fails to push the usage record', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ mockEsClient.search.mockResolvedValueOnce({
+ aggregations: { total_usage: 215 },
+ } as SearchResponse);
+
+ mockedAxiosPost.mockRejectedValueOnce(500);
+
+ const lastReportedUsageDate = new Date('2024-01-01T00:00:00.000Z');
+
+ const taskRunner = await createTaskRunner({ lastReportedUsageDate, projectId: 'test-project' });
+
+ const response = await taskRunner.run();
+
+ expect(response).toEqual({
+ state: {
+ lastReportedUsageDate,
+ attempts: 1,
+ },
+ runAt: new Date(nowDate.getTime() + 60000), // After a min
+ });
+ });
+
+ it('stops retrying after 5 attempts', async () => {
+ readFileSpy.mockImplementationOnce(() => '---CA CERTIFICATE---');
+ mockEsClient.search.mockResolvedValueOnce({
+ aggregations: { total_usage: 215 },
+ } as SearchResponse);
+
+ mockedAxiosPost.mockRejectedValueOnce(new Error('test-error'));
+
+ const lastReportedUsageDate = new Date('2024-01-01T00:00:00.000Z');
+
+ const taskRunner = await createTaskRunner({
+ lastReportedUsageDate,
+ projectId: 'test-project',
+ attempts: 4,
+ });
+
+ const response = await taskRunner.run();
+
+ expect(response).toEqual({
+ state: {
+ lastReportedUsageDate,
+ attempts: 0,
+ },
+ });
+
+ expect(logger.error).toHaveBeenCalledWith(
+ 'Usage data could not be pushed to usage-api. Stopped retrying after 5 attempts. Error:test-error'
+ );
+ });
+});
diff --git a/x-pack/plugins/actions/server/usage/connector_usage_reporting_task.ts b/x-pack/plugins/actions/server/usage/connector_usage_reporting_task.ts
new file mode 100644
index 0000000000000..ce44718749006
--- /dev/null
+++ b/x-pack/plugins/actions/server/usage/connector_usage_reporting_task.ts
@@ -0,0 +1,309 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import fs from 'fs';
+import { Logger, CoreSetup, type ElasticsearchClient } from '@kbn/core/server';
+import {
+ IntervalSchedule,
+ type ConcreteTaskInstance,
+ TaskManagerStartContract,
+ TaskManagerSetupContract,
+} from '@kbn/task-manager-plugin/server';
+import { AggregationsSumAggregate } from '@elastic/elasticsearch/lib/api/types';
+import axios from 'axios';
+import https from 'https';
+import { ActionsConfig } from '../config';
+import { ConnectorUsageReport } from './types';
+import { ActionsPluginsStart } from '../plugin';
+
+export const CONNECTOR_USAGE_REPORTING_TASK_SCHEDULE: IntervalSchedule = { interval: '1h' };
+export const CONNECTOR_USAGE_REPORTING_TASK_ID = 'connector_usage_reporting';
+export const CONNECTOR_USAGE_REPORTING_TASK_TYPE = `actions:${CONNECTOR_USAGE_REPORTING_TASK_ID}`;
+export const CONNECTOR_USAGE_REPORTING_TASK_TIMEOUT = 30000;
+export const CONNECTOR_USAGE_TYPE = `connector_request_body_bytes`;
+export const CONNECTOR_USAGE_REPORTING_SOURCE_ID = `task-connector-usage-report`;
+export const MAX_PUSH_ATTEMPTS = 5;
+
+export class ConnectorUsageReportingTask {
+ private readonly logger: Logger;
+ private readonly eventLogIndex: string;
+ private readonly projectId: string | undefined;
+ private readonly caCertificate: string | undefined;
+ private readonly usageApiUrl: string;
+
+ constructor({
+ logger,
+ eventLogIndex,
+ core,
+ taskManager,
+ projectId,
+ config,
+ }: {
+ logger: Logger;
+ eventLogIndex: string;
+ core: CoreSetup;
+ taskManager: TaskManagerSetupContract;
+ projectId: string | undefined;
+ config: ActionsConfig['usage'];
+ }) {
+ this.logger = logger;
+ this.projectId = projectId;
+ this.eventLogIndex = eventLogIndex;
+ this.usageApiUrl = config.url;
+ const caCertificatePath = config.ca?.path;
+
+ if (caCertificatePath && caCertificatePath.length > 0) {
+ try {
+ this.caCertificate = fs.readFileSync(caCertificatePath, 'utf8');
+ } catch (e) {
+ this.caCertificate = undefined;
+ this.logger.error(
+ `CA Certificate for the project "${projectId}" couldn't be loaded, Error: ${e.message}`
+ );
+ }
+ }
+
+ taskManager.registerTaskDefinitions({
+ [CONNECTOR_USAGE_REPORTING_TASK_TYPE]: {
+ title: 'Connector usage reporting task',
+ timeout: '1m',
+ createTaskRunner: ({ taskInstance }: { taskInstance: ConcreteTaskInstance }) => {
+ return {
+ run: async () => this.runTask(taskInstance, core),
+ cancel: async () => {},
+ };
+ },
+ },
+ });
+ }
+
+ public start = async (taskManager?: TaskManagerStartContract) => {
+ if (!taskManager) {
+ this.logger.error(
+ `Missing required task manager service during start of ${CONNECTOR_USAGE_REPORTING_TASK_TYPE}`
+ );
+ return;
+ }
+
+ try {
+ await taskManager.ensureScheduled({
+ id: CONNECTOR_USAGE_REPORTING_TASK_ID,
+ taskType: CONNECTOR_USAGE_REPORTING_TASK_TYPE,
+ schedule: {
+ ...CONNECTOR_USAGE_REPORTING_TASK_SCHEDULE,
+ },
+ state: {},
+ params: {},
+ });
+ } catch (e) {
+ this.logger.error(
+ `Error scheduling task ${CONNECTOR_USAGE_REPORTING_TASK_TYPE}, received ${e.message}`
+ );
+ }
+ };
+
+ private runTask = async (taskInstance: ConcreteTaskInstance, core: CoreSetup) => {
+ const { state } = taskInstance;
+
+ if (!this.projectId) {
+ this.logger.warn(
+ `Missing required project id while running ${CONNECTOR_USAGE_REPORTING_TASK_TYPE}`
+ );
+ return {
+ state,
+ };
+ }
+
+ if (!this.caCertificate) {
+ this.logger.error(
+ `Missing required CA Certificate while running ${CONNECTOR_USAGE_REPORTING_TASK_TYPE}`
+ );
+ return {
+ state,
+ };
+ }
+
+ const [{ elasticsearch }] = await core.getStartServices();
+ const esClient = elasticsearch.client.asInternalUser;
+
+ const now = new Date();
+ const oneDayAgo = new Date(new Date().getTime() - 24 * 60 * 60 * 1000);
+ const lastReportedUsageDate: Date = !!state.lastReportedUsageDate
+ ? new Date(state.lastReportedUsageDate)
+ : oneDayAgo;
+
+ let attempts: number = state.attempts || 0;
+
+ const fromDate = lastReportedUsageDate;
+ const toDate = now;
+
+ let totalUsage = 0;
+ try {
+ totalUsage = await this.getTotalUsage({
+ esClient,
+ fromDate,
+ toDate,
+ });
+ } catch (e) {
+ this.logger.error(`Usage data could not be fetched. It will be retried. Error:${e.message}`);
+ return {
+ state: {
+ lastReportedUsageDate,
+ attempts,
+ },
+ runAt: now,
+ };
+ }
+
+ const record: ConnectorUsageReport = this.createUsageRecord({
+ totalUsage,
+ fromDate,
+ toDate,
+ projectId: this.projectId,
+ });
+
+ this.logger.debug(`Record: ${JSON.stringify(record)}`);
+
+ try {
+ attempts = attempts + 1;
+ await this.pushUsageRecord(record);
+ this.logger.info(
+ `Connector usage record has been successfully reported, ${record.creation_timestamp}, usage: ${record.usage.quantity}, period:${record.usage.period_seconds}`
+ );
+ } catch (e) {
+ if (attempts < MAX_PUSH_ATTEMPTS) {
+ this.logger.error(
+ `Usage data could not be pushed to usage-api. It will be retried (${attempts}). Error:${e.message}`
+ );
+
+ return {
+ state: {
+ lastReportedUsageDate,
+ attempts,
+ },
+ runAt: this.getDelayedRetryDate({ attempts, now }),
+ };
+ }
+ this.logger.error(
+ `Usage data could not be pushed to usage-api. Stopped retrying after ${attempts} attempts. Error:${e.message}`
+ );
+ return {
+ state: {
+ lastReportedUsageDate,
+ attempts: 0,
+ },
+ };
+ }
+
+ return {
+ state: { lastReportedUsageDate: toDate, attempts: 0 },
+ };
+ };
+
+ private getTotalUsage = async ({
+ esClient,
+ fromDate,
+ toDate,
+ }: {
+ esClient: ElasticsearchClient;
+ fromDate: Date;
+ toDate: Date;
+ }): Promise => {
+ const usageResult = await esClient.search({
+ index: this.eventLogIndex,
+ sort: '@timestamp',
+ size: 0,
+ query: {
+ bool: {
+ filter: {
+ bool: {
+ must: [
+ {
+ term: { 'event.action': 'execute' },
+ },
+ {
+ term: { 'event.provider': 'actions' },
+ },
+ {
+ exists: {
+ field: 'kibana.action.execution.usage.request_body_bytes',
+ },
+ },
+ {
+ range: {
+ '@timestamp': {
+ gt: fromDate,
+ lte: toDate,
+ },
+ },
+ },
+ ],
+ },
+ },
+ },
+ },
+ aggs: {
+ total_usage: { sum: { field: 'kibana.action.execution.usage.request_body_bytes' } },
+ },
+ });
+
+ return (usageResult.aggregations?.total_usage as AggregationsSumAggregate)?.value ?? 0;
+ };
+
+ private createUsageRecord = ({
+ totalUsage,
+ fromDate,
+ toDate,
+ projectId,
+ }: {
+ totalUsage: number;
+ fromDate: Date;
+ toDate: Date;
+ projectId: string;
+ }): ConnectorUsageReport => {
+ const period = Math.round((toDate.getTime() - fromDate.getTime()) / 1000);
+ const toStr = toDate.toISOString();
+ const timestamp = new Date(toStr);
+ timestamp.setMinutes(0);
+ timestamp.setSeconds(0);
+ timestamp.setMilliseconds(0);
+
+ return {
+ id: `connector-request-body-bytes-${projectId}-${timestamp.toISOString()}`,
+ usage_timestamp: toStr,
+ creation_timestamp: toStr,
+ usage: {
+ type: CONNECTOR_USAGE_TYPE,
+ period_seconds: period,
+ quantity: totalUsage,
+ },
+ source: {
+ id: CONNECTOR_USAGE_REPORTING_SOURCE_ID,
+ instance_group_id: projectId,
+ },
+ };
+ };
+
+ private pushUsageRecord = async (record: ConnectorUsageReport) => {
+ return axios.post(this.usageApiUrl, [record], {
+ headers: { 'Content-Type': 'application/json' },
+ timeout: CONNECTOR_USAGE_REPORTING_TASK_TIMEOUT,
+ httpsAgent: new https.Agent({
+ ca: this.caCertificate,
+ }),
+ });
+ };
+
+ private getDelayedRetryDate = ({ attempts, now }: { attempts: number; now: Date }) => {
+ const baseDelay = 60 * 1000;
+ const delayByAttempts = baseDelay * attempts;
+
+ const delayedTime = now.getTime() + delayByAttempts;
+
+ return new Date(delayedTime);
+ };
+}
diff --git a/x-pack/plugins/actions/server/usage/types.ts b/x-pack/plugins/actions/server/usage/types.ts
index 6bdfe316c76e2..d57de6f4dad33 100644
--- a/x-pack/plugins/actions/server/usage/types.ts
+++ b/x-pack/plugins/actions/server/usage/types.ts
@@ -65,3 +65,18 @@ export const byServiceProviderTypeSchema: MakeSchemaFrom['count_ac
other: { type: 'long' },
ses: { type: 'long' },
};
+
+export interface ConnectorUsageReport {
+ id: string;
+ usage_timestamp: string;
+ creation_timestamp: string;
+ usage: {
+ type: string;
+ period_seconds: number;
+ quantity: number | string | undefined;
+ };
+ source: {
+ id: string | undefined;
+ instance_group_id: string;
+ };
+}
diff --git a/x-pack/plugins/actions/tsconfig.json b/x-pack/plugins/actions/tsconfig.json
index d060287d24143..384aba6a6b014 100644
--- a/x-pack/plugins/actions/tsconfig.json
+++ b/x-pack/plugins/actions/tsconfig.json
@@ -47,7 +47,8 @@
"@kbn/core-http-server",
"@kbn/core-test-helpers-kbn-server",
"@kbn/security-plugin-types-server",
- "@kbn/core-application-common"
+ "@kbn/core-application-common",
+ "@kbn/cloud-plugin"
],
"exclude": [
"target/**/*",
diff --git a/x-pack/plugins/alerting/common/routes/maintenance_window/apis/find/schemas/v1.ts b/x-pack/plugins/alerting/common/routes/maintenance_window/apis/find/schemas/v1.ts
index 0c79ae2480215..7c4dffdd1d94c 100644
--- a/x-pack/plugins/alerting/common/routes/maintenance_window/apis/find/schemas/v1.ts
+++ b/x-pack/plugins/alerting/common/routes/maintenance_window/apis/find/schemas/v1.ts
@@ -12,26 +12,24 @@ const MAX_DOCS = 10000;
export const findMaintenanceWindowsRequestQuerySchema = schema.object(
{
- page: schema.maybe(
- schema.number({
- defaultValue: 1,
- min: 1,
- max: MAX_DOCS,
- meta: {
- description: 'The page number to return.',
- },
- })
- ),
- per_page: schema.maybe(
- schema.number({
- defaultValue: 20,
- min: 0,
- max: 100,
- meta: {
- description: 'The number of maintenance windows to return per page.',
- },
- })
- ),
+ // we do not need to use schema.maybe here, because if we do not pass property page, defaultValue will be used
+ page: schema.number({
+ defaultValue: 1,
+ min: 1,
+ max: MAX_DOCS,
+ meta: {
+ description: 'The page number to return.',
+ },
+ }),
+ // we do not need to use schema.maybe here, because if we do not pass property per_page, defaultValue will be used
+ per_page: schema.number({
+ defaultValue: 1000,
+ min: 0,
+ max: 100,
+ meta: {
+ description: 'The number of maintenance windows to return per page.',
+ },
+ }),
},
{
validate: (params) => {
diff --git a/x-pack/plugins/canvas/server/plugin.ts b/x-pack/plugins/canvas/server/plugin.ts
index 074d29ec977f9..bf15dd31100ba 100644
--- a/x-pack/plugins/canvas/server/plugin.ts
+++ b/x-pack/plugins/canvas/server/plugin.ts
@@ -19,7 +19,6 @@ import { ReportingServerPluginSetup } from '@kbn/reporting-server';
import { getCanvasFeature } from './feature';
import { initRoutes } from './routes';
import { registerCanvasUsageCollector } from './collectors';
-import { loadSampleData } from './sample_data';
import { setupInterpreter } from './setup_interpreter';
import { customElementType, workpadTypeFactory, workpadTemplateType } from './saved_objects';
import type { CanvasSavedObjectTypeMigrationsDeps } from './saved_objects/migrations';
@@ -82,11 +81,6 @@ export class CanvasPlugin implements Plugin {
logger: this.logger,
});
- loadSampleData(
- plugins.home.sampleData.addSavedObjectsToSampleDataset,
- plugins.home.sampleData.addAppLinksToSampleDataset
- );
-
const getIndexForType = (type: string) =>
coreSetup
.getStartServices()
diff --git a/x-pack/plugins/canvas/server/sample_data/ecommerce_saved_objects.json b/x-pack/plugins/canvas/server/sample_data/ecommerce_saved_objects.json
deleted file mode 100644
index be5bc213e59a4..0000000000000
--- a/x-pack/plugins/canvas/server/sample_data/ecommerce_saved_objects.json
+++ /dev/null
@@ -1,1220 +0,0 @@
-[
- {
- "id": "workpad-e08b9bdb-ec14-4339-94c4-063bddfd610e",
- "type": "canvas-workpad",
- "updated_at": "2018-10-22T15:19:02.081Z",
- "version": 1,
- "migrationVersion": {
- "canvas-workpad": "7.0.0"
- },
- "attributes": {
- "name": "[eCommerce] Revenue Tracking",
- "width": 1080,
- "height": 720,
- "page": 0,
- "pages": [
- {
- "id": "page-21cffafb-9eda-47f9-b35a-67a92e605abe",
- "style": {
- "background": "#fff"
- },
- "elements": [
- {
- "id": "element-3a220f56-0729-4464-b4fd-7975a8396d24",
- "position": {
- "left": 641,
- "top": 97,
- "width": 175,
- "height": 510,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='MALE' THEN 1 else 0 END) as male_count from kibana_sample_data_ecommerce\"\n| math \"male_count / total_count\" \n| revealImage origin=\"bottom\" image={asset \"asset-aaa14d64-2c1c-47f2-95c0-21306ee18cba\"} emptyImage={asset \"asset-960c8c6e-da72-412d-9d04-34a98cdb5760\"}"
- },
- {
- "id": "element-4a3fef74-5d8c-4bbe-8f3f-fe55afdd4b60",
- "position": {
- "left": 627.5,
- "top": 82.5,
- "width": 197,
- "height": 521,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-8ae4b612-43a3-4846-8f0d-abb9785e95c3\"}"
- },
- {
- "id": "element-fb2761a1-df28-411a-8614-dbee0f437cfe",
- "position": {
- "left": 446,
- "top": 93,
- "width": 238,
- "height": 520,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='FEMALE' THEN 1 else 0 END) as female_count from kibana_sample_data_ecommerce\"\n| math \"female_count / total_count\" \n| revealImage origin=\"bottom\" image={asset \"asset-2f64bd10-953d-4163-90e9-a55e9ca4c52a\"} emptyImage={asset \"asset-3a26727a-b756-44be-a82c-273dd85bda09\"}",
- "filter": null
- },
- {
- "id": "element-46b2f8df-f7db-4502-9cd0-b33c1c70b8b1",
- "position": {
- "left": 275,
- "top": 306,
- "width": 105,
- "height": 102,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"65\" labels=false seriesStyle={seriesStyle label=\"Women's Clothing\" color=\"#eb6c66\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#ede9e7\"}"
- },
- {
- "id": "element-eaa7f9a9-54ca-4c7c-9d27-62312d92a264",
- "position": {
- "left": 275,
- "top": 157,
- "width": 105,
- "height": 102,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Accessories\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"65\" labels=false seriesStyle={seriesStyle label=\"Women's Accessories\" color=\"#eb6c66\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#ede9e7\"}"
- },
- {
- "id": "element-58dfc1e8-a470-447f-8107-62bebe955475",
- "position": {
- "left": 275,
- "top": 450,
- "width": 106,
- "height": 102,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"65\" labels=false seriesStyle={seriesStyle label=\"Women's Shoes\" color=\"#eb6c66\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#ede9e7\"}"
- },
- {
- "id": "element-c0a5f8d9-f52f-4e0f-a8a4-08c1b7984bb2",
- "position": {
- "left": 893.5,
- "top": 157,
- "width": 105,
- "height": 102,
- "angle": 0
- },
- "expression": "essql \"SELECT category, COUNT(category) AS count FROM \\\"kibana_sample_data_ecommerce\\\" GROUP BY category\" \n| mapColumn \"category\" fn={if {getCell \"category\" | eq \"Men's Accessories\"} then={getCell \"category\"} else=\"Other\"} \n| ply by=\"category\" fn={math \"sum(count)\" | as \"count\"} | staticColumn \"total\" value={math \"sum(count)\"} \n| mapColumn \"percentage\" fn={math \"round(count/total * 100, 2)\"} \n| pointseries color=\"category\" size=\"percentage\" \n| pie hole=\"65\" labels=false seriesStyle={seriesStyle label=\"Men's Accessories\" color=\"#f8bd4a\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#ede9e7\"}"
- },
- {
- "id": "element-060eb797-c583-4c8f-b0e1-3ab9b58c4cf5",
- "position": {
- "left": 894,
- "top": 305,
- "width": 105,
- "height": 102,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"65\" labels=false seriesStyle={seriesStyle label=\"Men's Clothing\" color=\"#f8bd4a\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#ede9e7\"}"
- },
- {
- "id": "element-8f811cd0-e4b2-48b3-a96f-b8384179bbfb",
- "position": {
- "left": 894,
- "top": 451,
- "width": 105,
- "height": 102,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"65\" labels=false seriesStyle={seriesStyle label=\"Men's Shoes\" color=\"#f8bd4a\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#ede9e7\"}"
- },
- {
- "id": "element-c0595f68-81c5-43e7-9ecf-808e8cfe48c0",
- "position": {
- "left": 298,
- "top": 517,
- "width": 93,
- "height": 44,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-66a89124-fc39-4109-8acd-e1ac7f382e04\"} | render"
- },
- {
- "id": "element-0a14f255-6445-4860-b41d-d1c0b7ca9c36",
- "position": {
- "left": 890,
- "top": 516,
- "width": 102,
- "height": 54,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-4acbecf1-e514-4e3b-bce4-61920335941e\"} | render"
- },
- {
- "id": "element-6aeefa4f-6b4f-4a6c-99ff-2cca052f5be6",
- "position": {
- "top": 291,
- "left": 960,
- "height": 121,
- "width": 95,
- "angle": 12.8
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-ae290f99-dd16-41a4-8191-7dd7be154be6\"} | render"
- },
- {
- "id": "element-68d9cb72-7a0e-4cac-996a-0ec8356f0df8",
- "position": {
- "left": 245,
- "top": 291,
- "width": 62,
- "height": 139,
- "angle": -1
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-565cd264-9196-4ebd-9d6e-f413f1db734d\"} | render"
- },
- {
- "id": "element-9bac6c19-517c-46e6-8d71-9273910366d1",
- "position": {
- "left": 322,
- "top": 230,
- "width": 60,
- "height": 27,
- "angle": 10
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-6222f3e0-1dab-4aa9-a06c-63d7732cc5f4\"} | render"
- },
- {
- "id": "element-a58f99d3-8ea4-474e-9aba-e7ed3e91a178",
- "position": {
- "left": 892,
- "top": 235,
- "width": 64,
- "height": 24,
- "angle": 7
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-f8ac482e-0c7a-4cac-8bcf-6f4f55300081\"} | render"
- },
- {
- "id": "element-84dec4fd-ee5d-49c0-9600-41b951033e09",
- "position": {
- "left": 394,
- "top": 393.0200895724113,
- "width": 94,
- "height": 56,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='FEMALE' THEN 1 else 0 END) as female_count from kibana_sample_data_ecommerce\"\n| math \"round(100 * female_count / total_count)\" | markdown {context} \"%\" font={font family=\"Avenir\" size=48 align=\"center\" color=\"#eb6c66\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-9e0b6230-2bc9-4995-8207-043e3063faeb",
- "position": {
- "left": 794,
- "top": 369,
- "width": 94,
- "height": 56,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='MALE' THEN 1 else 0 END) as male_count from kibana_sample_data_ecommerce\"\n| math \"round(100 * male_count / total_count)\" | markdown {context} \"%\" font={font family=\"Avenir\" size=48 align=\"center\" color=\"#f8bd4a\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-2185edff-ac50-4162-b583-3bfd6469e925",
- "position": {
- "left": -3,
- "top": -1,
- "width": 214,
- "height": 721,
- "angle": 0
- },
- "expression": "markdown \"\" | render containerStyle={containerStyle backgroundColor=\"#ede9e7\"}"
- },
- {
- "id": "element-71b63f54-0961-4ed2-a85d-45584b48a631",
- "position": {
- "left": 8,
- "top": 35,
- "width": 122,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"TOTAL SALES\" font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=18 align=\"left\" color=\"#777\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-61fdb4ce-5dea-4699-b958-6c40e2a2b61a",
- "position": {
- "left": 398,
- "top": 381.5200895724113,
- "width": 78,
- "height": 23,
- "angle": 0
- },
- "expression": "markdown \"WOMEN\" font={font family=\"Avenir\" size=18 align=\"left\" color=\"#999\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-157ab7a7-e3ef-477f-8c97-84c67f7ab28e",
- "position": {
- "left": 840,
- "top": 352,
- "width": 46,
- "height": 23,
- "angle": 0
- },
- "expression": "markdown \"MEN\" font={font family=\"Avenir\" size=18 align=\"left\" color=\"#999\" weight=\"normal\" underline=false italic=false} | render"
- },
- {
- "id": "element-bfa6f8bc-c083-4817-a682-91eb50fc214d",
- "position": {
- "left": 299,
- "top": 344,
- "width": 60,
- "height": 34,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Women's Clothing\"}}\n| markdown {getCell \"percentage\"} \"%\" font={font family=\"Avenir\" size=24 align=\"center\" color=\"#000\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-73e918d2-14d0-4ed6-9cfe-204ad4eaff24",
- "position": {
- "left": 300,
- "top": 488,
- "width": 59,
- "height": 30,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Women's Shoes\"}}\n| markdown {getCell \"percentage\"} \"%\" font={font family=\"Avenir\" size=24 align=\"center\" color=\"#000\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-d9dd8a8e-3af7-4e59-9115-3fd13c312d39",
- "position": {
- "left": 297,
- "top": 194,
- "width": 62,
- "height": 37,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Accessories\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Women's Accessories\"}}\n| markdown {getCell \"percentage\"} \"%\" font={font family=\"Avenir\" size=24 align=\"center\" color=\"#000\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-af25bb55-818c-4c69-b2ae-45245af131e6",
- "position": {
- "left": 923,
- "top": 194,
- "width": 51,
- "height": 34,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Accessories\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Men's Accessories\"}}\n| markdown {getCell \"percentage\"} \"%\" font={font family=\"Avenir\" size=24 align=\"center\" color=\"#000\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-9e02f39b-14b2-42a4-ae32-a4c292ece6ba",
- "position": {
- "left": 924,
- "top": 343,
- "width": 50,
- "height": 33,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Men's Clothing\"}}\n| markdown {getCell \"percentage\"} \"%\" font={font family=\"Avenir\" size=24 align=\"center\" color=\"#000\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-b5f950b0-bb0f-462d-a92f-35bc3f1f4c39",
- "position": {
- "left": 921,
- "top": 489,
- "width": 50,
- "height": 33,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Men's Shoes\"}}\n| markdown {getCell \"percentage\"} \"%\" font={font family=\"Avenir\" size=24 align=\"center\" color=\"#000\" weight=\"normal\" underline=false italic=false}"
- },
- {
- "id": "element-a4d410df-83b8-40dc-987f-e2c1380874a6",
- "position": {
- "left": -135.50000000000006,
- "top": 330.5,
- "width": 500,
- "height": 217,
- "angle": 90
- },
- "expression": "timelion \n \".es(index=kibana_sample_data_ecommerce, metric=sum:taxless_total_price, timefield=order_date)\" interval=\"1d\" from={essql \"SELECT order_date as min FROM kibana_sample_data_ecommerce order by order_date limit 1\" | getCell min} to={essql \"SELECT order_date as max FROM kibana_sample_data_ecommerce order by order_date DESC limit 1\" | getCell max}\n| pointseries x=\"@timestamp\" y=\"value\"\n| plot yaxis=false defaultStyle={seriesStyle points=\"0\" bars=\"50000000\" lines=\"0\" color=\"#62bb96\"} font={font size=12 family=\"Avenir\" color=\"#999\" align=\"left\"}",
- "filter": null
- },
- {
- "id": "element-ccbb192a-725b-4479-a34b-9d70b0fa1a8a",
- "position": {
- "left": 441,
- "top": 93,
- "width": 242,
- "height": 520,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-93e415d8-82c6-47d4-8c55-e38df329b88b\"}"
- },
- {
- "id": "element-18fc190c-e46a-408b-a220-8e1745eb77e6",
- "position": {
- "left": 394,
- "top": 451,
- "width": 115,
- "height": 2,
- "angle": 0
- },
- "expression": "markdown \"\" | render containerStyle={containerStyle backgroundColor=\"#000000\"}",
- "filter": null
- },
- {
- "id": "element-1eb4fcd1-f8dd-4bd9-98a6-c5cbd4bcc8dc",
- "position": {
- "left": 767,
- "top": 431,
- "width": 119,
- "height": 2,
- "angle": 0
- },
- "expression": "markdown \"\" | render containerStyle={containerStyle backgroundColor=\"#000000\"}",
- "filter": null
- },
- {
- "id": "element-2f976ef1-abc7-4bd2-82cb-cc114431eaea",
- "position": {
- "left": 744.5,
- "top": 410,
- "width": 35,
- "height": 50,
- "angle": 0
- },
- "expression": "markdown \"## ○\" font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=14 align=\"center\" color=\"#000000\" weight=\"normal\" underline=false italic=false} | render containerStyle={containerStyle}"
- },
- {
- "id": "element-532638f8-758e-4cf4-86f0-c4d896e4477d",
- "position": {
- "left": 497,
- "top": 429.4483902138134,
- "width": 35,
- "height": 50,
- "angle": 0
- },
- "expression": "markdown \"## ○\" font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=14 align=\"center\" color=\"#000000\" weight=\"normal\" underline=false italic=false} | render containerStyle={containerStyle}",
- "filter": null
- },
- {
- "id": "element-62bf98c1-bd0c-40dd-ae44-abbcc50c0ae1",
- "position": {
- "left": -47,
- "top": 410,
- "width": 477,
- "height": 63,
- "angle": 90
- },
- "expression": "timelion \n \".es(index=kibana_sample_data_ecommerce, metric=sum:taxless_total_price, timefield=order_date)\" interval=\"1w\"\n| mapColumn \"value\" fn={math \"round(value,0)\"}\n| staticColumn \"mean\" value={math \"round(mean(value),0)\"}\n| mapColumn \"mean\" \"as\" \"rnd\" fn={math \"round(random(0.9,1.1),2)\"}\n| mapColumn \"value\" \"as\" \"final\" fn={math \"round(multiply(rnd,mean),2)\"}\n| pointseries x=\"@timestamp\" y=\"final\"\n| plot xaxis=false yaxis=false defaultStyle={seriesStyle points=\"0\" bars=\"0\" lines=\"3\" color=\"#eb6c66\"}\n| render containerStyle={containerStyle opacity=\"0.5\"}",
- "filter": null
- },
- {
- "id": "element-e1b5a809-aed3-42e0-8806-46b0e462a9d4",
- "position": {
- "left": 488,
- "top": 661,
- "width": 279,
- "height": 38,
- "angle": 0
- },
- "expression": "markdown \"REVENUE BY CATEGORY\" font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=24 align=\"left\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-50ea8d53-383d-4582-9497-0692a81d9df8",
- "position": {
- "left": -7,
- "top": 673,
- "width": 219,
- "height": 22,
- "angle": 0
- },
- "expression": "markdown \"REVENUE BY DAY\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=14 align=\"center\" color=\"#62bb96\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-de932ce1-1c99-448b-bfb4-a98f91add877",
- "position": {
- "left": -7,
- "top": 689,
- "width": 219,
- "height": 22,
- "angle": 0
- },
- "expression": "markdown \"SALES PREDICTION\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#eb6c66\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-f5f539dd-1abe-42a9-bb2a-1d2a07ff108c",
- "position": {
- "left": 286,
- "top": 263,
- "width": 76,
- "height": 16,
- "angle": 0
- },
- "expression": "markdown \"ACCESSORIES\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-1eb8a1d1-beff-4d42-8b82-cddc28075bb0",
- "position": {
- "left": 911,
- "top": 262,
- "width": 76,
- "height": 16,
- "angle": 0
- },
- "expression": "markdown \"ACCESSORIES\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-d36fd045-500a-494c-8d1f-281c03a9720d",
- "position": {
- "left": 909,
- "top": 409,
- "width": 76,
- "height": 16,
- "angle": 0
- },
- "expression": "markdown \"CLOTHING\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-3388ba84-9109-4f1e-bb3b-8e7e4247b99e",
- "position": {
- "left": 291,
- "top": 411,
- "width": 76,
- "height": 16,
- "angle": 0
- },
- "expression": "markdown \"CLOTHING\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-4fe5f99e-ffea-4d21-9718-dbfbbd161a64",
- "position": {
- "left": 910,
- "top": 570,
- "width": 76,
- "height": 16,
- "angle": 0
- },
- "expression": "markdown \"SHOES\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-a6b5a208-6a75-42ad-8a1c-aa50359ecd44",
- "position": {
- "left": 293,
- "top": 562,
- "width": 76,
- "height": 16,
- "angle": 0
- },
- "expression": "markdown \"SHOES\" \n font={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=10 align=\"center\" color=\"#999\" weight=\"normal\" underline=false italic=false}",
- "filter": null
- },
- {
- "id": "element-45310e03-f6dd-4283-aa04-8d27a4501665",
- "position": {
- "left": 5.999999999999915,
- "top": 76.5,
- "width": 201.00000000000009,
- "height": 68.5,
- "angle": 0
- },
- "expression": "essql \n query=\"SELECT sum(taxless_total_price) AS sum_total_price FROM \\\"kibana_sample_data_ecommerce\\\"\"\n| math \"sum_total_price\"\n| formatNumber \"$0a\"\n| metric \n metricFont={font family=\"'Avenir', Helvetica, Arial, sans-serif\" size=72 align=\"left\" color=\"#000000\" weight=\"normal\" underline=false italic=false}\n| render"
- }
- ]
- },
- {
- "id": "page-f704531f-3a72-4f29-a199-7e00d0c1ffef",
- "style": {
- "background": "#FAF0DD"
- },
- "elements": [
- {
- "id": "element-2c7e18fa-480f-4e3b-b4df-f649687229c6",
- "position": {
- "left": 788,
- "top": 112.12093494719988,
- "width": 204,
- "height": 202,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='MALE' THEN 1 else 0 END) as male_count from kibana_sample_data_ecommerce\"\n| math \"male_count / total_count\" \n| revealImage origin=\"bottom\" image={asset \"asset-803ec373-2608-4f6f-8cf9-0dbb2f6437ce\"} emptyImage={asset \"asset-18070a2a-cd01-410a-ba89-a4505e2fbc5b\"}"
- },
- {
- "id": "element-2379c3ca-2c31-4948-8412-d14115500efc",
- "position": {
- "left": 788,
- "top": 369.6303606465582,
- "width": 204,
- "height": 202,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='FEMALE' THEN 1 else 0 END) as female_count from kibana_sample_data_ecommerce\"\n| math \"female_count / total_count\" \n| revealImage origin=\"bottom\" image={asset \"asset-e644a484-4097-40b9-a08e-7250ba963059\"} emptyImage={asset \"asset-7e4f7119-b2d8-4527-9bd8-887cb25974e7\"}"
- },
- {
- "id": "element-3f52813f-7d0e-4ec7-9aad-c731b670d88d",
- "position": {
- "left": -69,
- "top": 400.19203602130153,
- "width": 388,
- "height": 141,
- "angle": 90
- },
- "expression": "timelion \n \".es(index=kibana_sample_data_ecommerce, metric=sum:taxless_total_price, timefield=order_date)\" interval=\"1d\" from={essql \"SELECT order_date as min FROM kibana_sample_data_ecommerce order by order_date limit 1\" | getCell min} to={essql \"SELECT order_date as max FROM kibana_sample_data_ecommerce order by order_date DESC limit 1\" | getCell max}\n| pointseries x=\"@timestamp\" y=\"value\"\n| plot yaxis=false defaultStyle={seriesStyle points=\"0\" bars=\"50000000\" lines=\"0\" color=\"#00A89C\"} \n font={font family=\"gilroy extrabold, Avenir\" size=16 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-dc86d147-0611-4ce8-9b0b-e95fc6f8ab80",
- "position": {
- "left": 244,
- "top": 138,
- "width": 157,
- "height": 145,
- "angle": -45
- },
- "expression": "essql \"SELECT category, COUNT(category) AS count FROM \\\"kibana_sample_data_ecommerce\\\" GROUP BY category\" \n| mapColumn \"category\" fn={if {getCell \"category\" | eq \"Men's Accessories\"} then={getCell \"category\"} else=\"Other\"} \n| ply by=\"category\" fn={math \"sum(count)\" | as \"count\"} | staticColumn \"total\" value={math \"sum(count)\"} \n| mapColumn \"percentage\" fn={math \"round(count/total * 100, 2)\"} \n| pointseries color=\"category\" size=\"percentage\"\n| pie hole=\"85\" labels=false seriesStyle={seriesStyle label=\"Men's Accessories\" color=\"#00A89C\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#CBCBCB\"}"
- },
- {
- "id": "element-29967798-174d-4109-b229-e776b0a4bf8c",
- "position": {
- "left": 425.5,
- "top": 138,
- "width": 157,
- "height": 145,
- "angle": -99
- },
- "expression": "essql \n \"SELECT category, COUNT(category) AS count FROM \\\"kibana_sample_data_ecommerce\\\" GROUP BY category ORDER BY category\"\n| mapColumn \"category\" \n fn={if {getCell \"category\" | eq \"Men's Clothing\"} then={getCell \"category\"} else=\"Other\"}\n| ply by=\"category\" fn={math \"sum(count)\" | as \"count\"}\n| staticColumn \"total\" value={math \"sum(count)\"}\n| mapColumn \"percentage\" fn={math \"round(count/total * 100, 2)\"}\n| sort \"category\"\n| pointseries color=\"category\" size=\"percentage\"\n| pie hole=\"85\" labels=false seriesStyle={seriesStyle label=\"Men's Clothing\" color=\"#00A89C\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#CBCBCB\"}"
- },
- {
- "id": "element-abaa4e35-cfc0-4171-8c34-0914cea35082",
- "position": {
- "left": 610,
- "top": 136,
- "width": 157,
- "height": 145,
- "angle": -56
- },
- "expression": "essql \"SELECT category, COUNT(category) AS count FROM \\\"kibana_sample_data_ecommerce\\\" GROUP BY category\" \n| mapColumn \"category\" fn={if {getCell \"category\" | eq \"Men's Shoes\"} then={getCell \"category\"} else=\"Other\"} \n| ply by=\"category\" fn={math \"sum(count)\" | as \"count\"} | staticColumn \"total\" value={math \"sum(count)\"} \n| mapColumn \"percentage\" fn={math \"round(count/total * 100, 2)\"} \n| pointseries color=\"category\" size=\"percentage\"\n| pie hole=\"85\" labels=false seriesStyle={seriesStyle label=\"Men's Shoes\" color=\"#00A89C\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#CBCBCB\"}"
- },
- {
- "id": "element-20da5d5d-2b29-4888-a304-a14377d727ec",
- "position": {
- "left": 245,
- "top": 383,
- "width": 157,
- "height": 145,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Accessories\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"85\" labels=false palette={palette \"#CBCBCB\" \"#F05A24\" gradient=false} seriesStyle={seriesStyle label=\"Women's Accessories\" color=\"#F05A24\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#CBCBCB\"}"
- },
- {
- "id": "element-9dd99310-e0a6-4ab7-b049-c7ea63180b4e",
- "position": {
- "left": 429,
- "top": 380,
- "width": 157,
- "height": 145,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"85\" labels=false seriesStyle={seriesStyle label=\"Women's Clothing\" color=\"#F05A24\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#CBCBCB\"}"
- },
- {
- "id": "element-715b318d-fe6d-42b2-abea-b238b0daa8c7",
- "position": {
- "left": 610,
- "top": 384,
- "width": 157,
- "height": 145,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 2)'}\n| pointseries color=category size=percentage\n| pie hole=\"85\" labels=false seriesStyle={seriesStyle label=\"Women's Shoes\" color=\"#F05A24\"}\n seriesStyle={seriesStyle label=\"Other\" color=\"#CBCBCB\"}"
- },
- {
- "id": "element-9c27c6d0-b9d9-4adb-a5f3-abb7a3403977",
- "position": {
- "left": 239,
- "top": 157,
- "width": 172,
- "height": 102,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-e79711e8-d9da-45e1-a234-9efe226a444d\"}\n| render"
- },
- {
- "id": "element-c9b7f707-f27c-44cc-b9f1-e7b693c66702",
- "position": {
- "left": 463,
- "top": 165,
- "width": 85,
- "height": 86,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-9493e336-1b11-4e61-bad2-716c46194550\"}\n| render"
- },
- {
- "id": "element-8bcb4071-0012-46da-9316-524c06bb673a",
- "position": {
- "left": 648,
- "top": 165,
- "width": 85,
- "height": 86,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-23f2bfe9-e58c-4a56-98c6-fad59eecdf74\"}\n| render"
- },
- {
- "id": "element-3532c81f-a341-4d23-90b6-68912c04ee46",
- "position": {
- "left": 1016,
- "top": 391,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"W\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-2673d24b-2706-4ffe-a38b-5736c3bc616c",
- "position": {
- "left": 1018,
- "top": 420,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"O\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-5d2b6fe8-34a9-49bc-8229-4e1c2b8029e1",
- "position": {
- "left": 1018,
- "top": 446,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"M\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-b67e44c0-afe0-4f15-b521-af0759348dc6",
- "position": {
- "left": 1020,
- "top": 475,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"E\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-370b7910-dd0b-4257-90de-229d25bd6610",
- "position": {
- "left": 1019,
- "top": 504,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"N\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-cbdd2309-101d-4edc-874c-47c3e6c99df5",
- "position": {
- "left": 1018,
- "top": 173,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"M\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-7288cfda-673f-4741-bec2-4675bc4952ed",
- "position": {
- "left": 1020,
- "top": 201,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"E\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-e68822cc-f4b7-48a4-a8b2-86d84d8ddeb1",
- "position": {
- "left": 1019,
- "top": 229,
- "width": 78,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"N\" \n font={font family=\"gilroy extrabold, Avenir\" size=24 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-f446c8e1-b65e-4a1f-8476-e80e437a31ec",
- "position": {
- "left": 240,
- "top": 414,
- "width": 169,
- "height": 100,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-86d05b5e-1a4b-4979-95e9-7071b9923470\"}\n| render"
- },
- {
- "id": "element-5406c1e9-9626-413c-9eaa-a73ca1e10b8c",
- "position": {
- "left": 464,
- "top": 414,
- "width": 85,
- "height": 86,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-fdfc9cc7-2c6a-44fe-b9be-c4ff115c92c1\"}\n| render"
- },
- {
- "id": "element-d3fe9442-583b-4acb-a700-3935adb4316c",
- "position": {
- "left": 654,
- "top": 419,
- "width": 74,
- "height": 76,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-58ae3445-4001-45e7-9603-19ec8d41e64e\"}\n| render"
- },
- {
- "id": "element-28ffc136-8702-4cfc-9643-9825dfd7a6a3",
- "position": {
- "left": 48,
- "top": 247,
- "width": 118,
- "height": 22,
- "angle": 0
- },
- "expression": "markdown \"P R O G R E S S\" \n font={font family=\"gilroy extrabold, Avenir\" size=12 align=\"center\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-c6b853cc-72a3-4110-b40b-359ecb7b1af6",
- "position": {
- "left": 92,
- "top": 268,
- "width": 27,
- "height": 4,
- "angle": 0
- },
- "expression": "markdown \"\"\n| render containerStyle={containerStyle backgroundColor=\"#F05A24\"}"
- },
- {
- "id": "element-692a539e-0c3b-4e8d-bc3e-3cf84ddd53c7",
- "position": {
- "left": 90,
- "top": 98,
- "width": 27,
- "height": 4,
- "angle": 0
- },
- "expression": "markdown \"\"\n| render containerStyle={containerStyle backgroundColor=\"#F05A24\"}"
- },
- {
- "id": "element-99bed359-ef39-403d-bcb3-81cf8d1f6c62",
- "position": {
- "left": 44,
- "top": 77,
- "width": 118,
- "height": 22,
- "angle": 0
- },
- "expression": "markdown \"T O T A L\" \n font={font family=\"gilroy extrabold, Avenir\" size=12 align=\"center\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-8d72d271-b12e-41af-a18b-795490cf7f38",
- "position": {
- "left": 276,
- "top": 290,
- "width": 93,
- "height": 40,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Accessories\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Men's Accessories\"}}\n| markdown {getCell \"percentage\"} font={font family=\"nexa bold, Avenir\" size=36 align=\"center\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-cc17144e-096c-47b1-85dc-047724cc095e",
- "position": {
- "left": 465,
- "top": 291,
- "width": 78,
- "height": 40,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Men's Clothing\"}}\n| markdown {getCell \"percentage\"} font={font family=\"nexa bold, Avenir\" size=36 align=\"center\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-f38ee1d6-4fd7-4ff9-b304-84663f60fab2",
- "position": {
- "left": 651,
- "top": 290,
- "width": 76,
- "height": 40,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Men's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Men's Shoes\"}}\n| markdown {getCell \"percentage\"} font={font family=\"nexa bold, Avenir\" size=36 align=\"center\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-0b0b1c4a-0acf-40e3-a3f0-3128bd59f45c",
- "position": {
- "left": 340,
- "top": 293,
- "width": 47,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=24 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-3efcd68f-7fca-4ad3-aa13-737260ec5436",
- "position": {
- "left": 525,
- "top": 293,
- "width": 47,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=24 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-a617cb84-6e50-47c3-bb95-ea67df89d117",
- "position": {
- "left": 710,
- "top": 292,
- "width": 47,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=24 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-5426b988-29d6-40aa-b0a2-40a4a0729ef0",
- "position": {
- "left": 277,
- "top": 540,
- "width": 93,
- "height": 40,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Accessories\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Women's Accessories\"}}\n| markdown {getCell \"percentage\"} \"\" font={font family=\"nexa bold, Avenir\" size=36 align=\"center\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-c1579899-59fc-4960-9bf0-1187b3535593",
- "position": {
- "left": 461,
- "top": 541,
- "width": 93,
- "height": 40,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Clothing\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Women's Clothing\"}}\n| markdown {getCell \"percentage\"} font={font family=\"nexa bold, Avenir\" size=36 align=\"center\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-31df9407-2156-408d-b9d4-54e32adfdc2b",
- "position": {
- "left": 644,
- "top": 541,
- "width": 93,
- "height": 40,
- "angle": 0
- },
- "expression": "essql 'SELECT category, COUNT(category) AS count FROM \"kibana_sample_data_ecommerce\" GROUP BY category'\n| mapColumn category fn={if {getCell category | eq \"Women's Shoes\"} then={getCell category} else=\"Other\"}\n| ply by=category fn={math 'sum(count)' | as count}\n| staticColumn total value={math 'sum(count)'}\n| mapColumn percentage fn={math 'round(count/total * 100, 0)'}\n| filterrows {getCell \"category\" | any {eq \"Women's Shoes\"}}\n| markdown {getCell \"percentage\"} font={font family=\"nexa bold, Avenir\" size=36 align=\"center\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-d82b37e0-2f8e-48cb-8a85-d3d22b019499",
- "position": {
- "left": 343,
- "top": 543,
- "width": 45,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-ae570ea8-06b8-4ffa-a2f1-b7281481779f",
- "position": {
- "left": 528,
- "top": 543,
- "width": 45,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-81dd855d-d4fa-4c1c-a72f-6c6ab5b100cf",
- "position": {
- "left": 711,
- "top": 543,
- "width": 45,
- "height": 29,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=24 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-b8f13a87-b781-42d5-a663-5dbd4f645d6d",
- "position": {
- "left": 837,
- "top": 468,
- "width": 91,
- "height": 63,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='FEMALE' THEN 1 else 0 END) as female_count from kibana_sample_data_ecommerce\"\n| math \"round(100 * female_count / total_count)\" | markdown {context} font={font family=\"nexa bold, Avenir\" size=48 align=\"center\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-86b06b67-893e-4555-ad38-7fba9ea3153b",
- "position": {
- "left": 837,
- "top": 215,
- "width": 90,
- "height": 72,
- "angle": 0
- },
- "expression": "essql query=\"select COUNT(*) as total_count, SUM(CASE WHEN customer_gender='MALE' THEN 1 else 0 END) as male_count from kibana_sample_data_ecommerce\"\n| math \"round(100 * male_count / total_count)\" | markdown {context} font={font family=\"nexa bold, Avenir\" size=48 align=\"center\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-507337d9-6e0e-4752-8770-6ebe88e9b3da",
- "position": {
- "left": 913,
- "top": 220,
- "width": 44,
- "height": 42,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=36 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-19f6b029-a6ef-426e-aa07-8f91ef846a95",
- "position": {
- "left": 914,
- "top": 475,
- "width": 44,
- "height": 42,
- "angle": 0
- },
- "expression": "markdown \"%\" \n font={font family=\"nexa extrabold, Avenir\" size=36 align=\"left\" color=\"#F05A24\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-8ef60cfc-3823-42b6-9651-75a07b8e412d",
- "position": {
- "left": 19,
- "top": 124,
- "width": 44,
- "height": 42,
- "angle": 0
- },
- "expression": "markdown \"$\" \n font={font family=\"nexa bold, Avenir\" size=36 align=\"left\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-3dfda897-cc59-4bf6-ad3d-38f00bd8814b",
- "position": {
- "left": 362,
- "top": 606,
- "width": 378,
- "height": 92,
- "angle": 0
- },
- "expression": "markdown \"ACME Inc.\" font={font family=\"gilroy extrabold, Avenir\" size=72 align=\"center\" color=\"#CDCDCD\" weight=\"bold\" underline=false italic=false}"
- },
- {
- "id": "element-b336534a-6604-41be-b34a-109d631dcdb2",
- "position": {
- "left": 27.25,
- "top": 133.03796394394163,
- "width": 195.5,
- "height": 80.08297100325825,
- "angle": 0
- },
- "expression": "essql \n query=\"SELECT sum(taxless_total_price) AS sum_total_price FROM \\\"kibana_sample_data_ecommerce\\\"\"\n| math \"sum_total_price\"\n| formatNumber \"0a\"\n| metric \n metricFont={font family=\"nexa bold, Avenir\" size=72 align=\"center\" color=\"#00A89C\" weight=\"bold\" underline=false italic=false}\n| render"
- }
- ]
- }
- ],
- "colors": [
- "#37988d",
- "#c19628",
- "#b83c6f",
- "#3f9939",
- "#1785b0",
- "#ca5f35",
- "#45bdb0",
- "#f2bc33",
- "#e74b8b",
- "#4fbf48",
- "#1ea6dc",
- "#fd7643",
- "#72cec3",
- "#f5cc5d",
- "#ec77a8",
- "#7acf74",
- "#4cbce4",
- "#fd986f",
- "#a1ded7",
- "#f8dd91",
- "#f2a4c5",
- "#a6dfa2",
- "#86d2ed",
- "#fdba9f",
- "#000000",
- "#444444",
- "#777777",
- "#BBBBBB",
- "#FFFFFF",
- "rgba(255,255,255,0)"
- ],
- "@timestamp": "2019-03-18T17:22:07.449Z",
- "@created": "2019-03-18T16:05:37.945Z",
- "assets": {
- "asset-66a89124-fc39-4109-8acd-e1ac7f382e04": {
- "id": "asset-66a89124-fc39-4109-8acd-e1ac7f382e04",
- "@created": "2018-07-10T18:33:25.683Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-4acbecf1-e514-4e3b-bce4-61920335941e": {
- "id": "asset-4acbecf1-e514-4e3b-bce4-61920335941e",
- "@created": "2018-07-10T18:34:30.379Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-ae290f99-dd16-41a4-8191-7dd7be154be6": {
- "id": "asset-ae290f99-dd16-41a4-8191-7dd7be154be6",
- "@created": "2018-07-10T18:37:50.932Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-565cd264-9196-4ebd-9d6e-f413f1db734d": {
- "id": "asset-565cd264-9196-4ebd-9d6e-f413f1db734d",
- "@created": "2018-07-10T18:38:37.796Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-6222f3e0-1dab-4aa9-a06c-63d7732cc5f4": {
- "id": "asset-6222f3e0-1dab-4aa9-a06c-63d7732cc5f4",
- "@created": "2018-07-10T18:39:47.394Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-f8ac482e-0c7a-4cac-8bcf-6f4f55300081": {
- "id": "asset-f8ac482e-0c7a-4cac-8bcf-6f4f55300081",
- "@created": "2018-07-10T18:40:34.480Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-2f64bd10-953d-4163-90e9-a55e9ca4c52a": {
- "id": "asset-2f64bd10-953d-4163-90e9-a55e9ca4c52a",
- "@created": "2018-07-13T13:12:49.516Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-3a26727a-b756-44be-a82c-273dd85bda09": {
- "id": "asset-3a26727a-b756-44be-a82c-273dd85bda09",
- "@created": "2018-07-13T13:12:56.611Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-93e415d8-82c6-47d4-8c55-e38df329b88b": {
- "id": "asset-93e415d8-82c6-47d4-8c55-e38df329b88b",
- "@created": "2018-07-13T13:13:02.894Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-aaa14d64-2c1c-47f2-95c0-21306ee18cba": {
- "id": "asset-aaa14d64-2c1c-47f2-95c0-21306ee18cba",
- "@created": "2018-07-13T13:14:32.348Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-960c8c6e-da72-412d-9d04-34a98cdb5760": {
- "id": "asset-960c8c6e-da72-412d-9d04-34a98cdb5760",
- "@created": "2018-07-13T13:14:42.533Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-8ae4b612-43a3-4846-8f0d-abb9785e95c3": {
- "id": "asset-8ae4b612-43a3-4846-8f0d-abb9785e95c3",
- "@created": "2018-07-13T13:15:19.432Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-b1602228-f014-402d-88cd-42821af09dcf": {
- "id": "asset-b1602228-f014-402d-88cd-42821af09dcf",
- "@created": "2018-08-21T18:29:08.616Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-18070a2a-cd01-410a-ba89-a4505e2fbc5b": {
- "id": "asset-18070a2a-cd01-410a-ba89-a4505e2fbc5b",
- "@created": "2018-09-06T19:41:55.368Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-803ec373-2608-4f6f-8cf9-0dbb2f6437ce": {
- "id": "asset-803ec373-2608-4f6f-8cf9-0dbb2f6437ce",
- "@created": "2018-09-06T19:42:19.366Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-466fdcbd-f265-4081-bbcc-367bfcfeaf4f": {
- "id": "asset-466fdcbd-f265-4081-bbcc-367bfcfeaf4f",
- "@created": "2018-09-06T19:43:02.342Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-e644a484-4097-40b9-a08e-7250ba963059": {
- "id": "asset-e644a484-4097-40b9-a08e-7250ba963059",
- "@created": "2018-09-06T19:44:43.075Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-7e4f7119-b2d8-4527-9bd8-887cb25974e7": {
- "id": "asset-7e4f7119-b2d8-4527-9bd8-887cb25974e7",
- "@created": "2018-09-06T19:44:52.474Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-e79711e8-d9da-45e1-a234-9efe226a444d": {
- "id": "asset-e79711e8-d9da-45e1-a234-9efe226a444d",
- "@created": "2018-09-06T20:01:04.447Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-9493e336-1b11-4e61-bad2-716c46194550": {
- "id": "asset-9493e336-1b11-4e61-bad2-716c46194550",
- "@created": "2018-09-06T20:01:22.463Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-23f2bfe9-e58c-4a56-98c6-fad59eecdf74": {
- "id": "asset-23f2bfe9-e58c-4a56-98c6-fad59eecdf74",
- "@created": "2018-09-06T20:01:50.445Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-86d05b5e-1a4b-4979-95e9-7071b9923470": {
- "id": "asset-86d05b5e-1a4b-4979-95e9-7071b9923470",
- "@created": "2018-09-06T20:17:48.355Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-fdfc9cc7-2c6a-44fe-b9be-c4ff115c92c1": {
- "id": "asset-fdfc9cc7-2c6a-44fe-b9be-c4ff115c92c1",
- "@created": "2018-09-06T20:18:11.818Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-58ae3445-4001-45e7-9603-19ec8d41e64e": {
- "id": "asset-58ae3445-4001-45e7-9603-19ec8d41e64e",
- "@created": "2018-09-06T20:18:30.635Z",
- "type": "dataurl",
- "value": ""
- }
- }
- }
- }
-]
diff --git a/x-pack/plugins/canvas/server/sample_data/flights_saved_objects.json b/x-pack/plugins/canvas/server/sample_data/flights_saved_objects.json
deleted file mode 100644
index a93d34bce5098..0000000000000
--- a/x-pack/plugins/canvas/server/sample_data/flights_saved_objects.json
+++ /dev/null
@@ -1,512 +0,0 @@
-[
- {
- "id": "workpad-a474e74b-aedc-47c3-894a-db77e62c41e0",
- "type": "canvas-workpad",
- "updated_at": "2018-10-22T14:17:04.040Z",
- "version": 1,
- "migrationVersion": {
- "canvas-workpad": "7.0.0"
- },
- "attributes": {
- "name": "[Flights] Overview",
- "width": 1280,
- "height": 720,
- "page": 0,
- "pages": [
- {
- "id": "page-261eb6da-4ab2-400d-b1be-b72cbbcf58ff",
- "style": { "background": "#f4f4f4" },
- "transition": { "name": "" },
- "elements": [
- {
- "id": "element-5929e53d-4dad-49a5-a432-8de3b1d05b82",
- "position": {
- "left": 855.5,
- "top": 185.312409153891,
- "width": 407,
- "height": 140.250363384436,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-60c9ac53-47a7-4ec2-a975-9d10bbe038bb",
- "position": {
- "left": 855.5,
- "top": 26,
- "width": 407,
- "height": 140.250363384436,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-f573cae3-0d2b-4265-9a6f-314c865c4e5c",
- "position": {
- "left": 423.5251242870414,
- "top": 26,
- "width": 407,
- "height": 140.250363384436,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-0f5b4a1f-8107-4f84-a12f-755b41dd1ca9",
- "position": {
- "left": 1035,
- "top": 50.5,
- "width": 197,
- "height": 99,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT COUNT(DISTINCT OriginAirportID) as total_airports\nFROM kibana_sample_data_flights\"\n| math \"total_airports\"\n| metric \"AIRPORTS\"\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=60 align=\"right\" color=\"#43988F\" weight=\"normal\" underline=false italic=false}\nlabelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"right\" color=\"#43988F\" weight=\"normal\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-096136f5-279d-4d29-a784-1bd33243db29",
- "position": {
- "left": 443.5,
- "top": 275.250363384436,
- "width": 131,
- "height": 33,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"### LONGEST FLIGHT\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=10 align=\"left\" color=\"#FFFFFF\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-3d1e17df-6310-4968-8323-f0bcabf593e3",
- "position": {
- "left": 1042.5,
- "top": 211.84415880749052,
- "width": 191,
- "height": 92.812409153891,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT MAX(DistanceMiles) as max_distance\nFROM kibana_sample_data_flights\nWHERE DistanceMiles > 0\"\n| math \"max_distance\"\n| formatNumber \"00.0a\"\n| metric \"MILES\"\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=60 align=\"right\" color=\"#EFB341\" weight=\"normal\" underline=false italic=false}\nlabelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"right\" color=\"#EFB341\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-3604ef7b-8f10-4a5f-a4b9-f123e32960dd",
- "position": {
- "left": 1036,
- "top": -51,
- "width": 246,
- "height": 50,
- "angle": 0
- },
- "expression": "\ntimefilterControl compact=true column=\"timestamp\"\n| render\n",
- "filter": "timefilter from=\"now-24h\" to=now column=timestamp"
- },
- {
- "id": "element-08333e7c-2986-4ee7-b07c-8c07be09c751",
- "position": {
- "left": -1,
- "top": 386.250363384436,
- "width": 1283,
- "height": 358,
- "angle": 0
- },
- "expression": "\nimage mode=\"cover\" dataurl={asset \"asset-2da3aba1-6e0f-4a79-879e-0ab3cfa170d6\"}\n| render\n"
- },
- {
- "id": "element-90336033-8ca4-4bf5-ad20-94162aec28b6",
- "position": {
- "left": 26,
- "top": 26,
- "width": 375.5,
- "height": 672.125545076654,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-e0ff80ac-8372-421f-918e-fd9f257b2f32",
- "position": {
- "left": -27,
- "top": -1,
- "width": 462,
- "height": 699.125545076654,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-9e41d208-ec45-472d-a118-e2e2c811291b\"}\n| render\n"
- },
- {
- "id": "element-0d68f8e7-dc04-4358-b459-127c42e274b4",
- "position": {
- "left": 26,
- "top": 145,
- "width": 375.5,
- "height": 153.375181692218,
- "angle": 0
- },
- "expression": "\nshape \"circle\" fill=\"rgba(255,255,255,0)\" border=\"#48A8E0\" borderWidth=2 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-f56821a4-4fd8-4de1-8bb7-6722c9ee5334",
- "position": {
- "left": 26,
- "top": 56,
- "width": 375.5,
- "height": 44,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"TIME IN AIR\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=36 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-210b8adc-c5fa-412b-b280-146863fc9230",
- "position": {
- "left": 26,
- "top": 330.562772538327,
- "width": 375.5,
- "height": 153.375181692218,
- "angle": 0
- },
- "expression": "\nshape \"circle\" fill=\"rgba(255,255,255,0)\" border=\"#48A8E0\" borderWidth=2 maintainAspect=true\n| render\n",
- "filter": null
- },
- {
- "id": "element-002f28e5-a132-4cbb-b1cb-f13f1cdeaac2",
- "position": {
- "left": 26,
- "top": 509.562772538327,
- "width": 375.5,
- "height": 153.375181692218,
- "angle": 0
- },
- "expression": "\nshape \"circle\" fill=\"rgba(255,255,255,0)\" border=\"#48A8E0\" borderWidth=2 maintainAspect=true\n| render\n",
- "filter": null
- },
- {
- "id": "element-8a1248fa-2c2e-4be4-9e2b-95198279144d",
- "position": {
- "left": 26,
- "top": 366.062772538327,
- "width": 375.5,
- "height": 65,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT FLOOR((SUM(FlightTimeMin) % 1440) / 60) as total_hours\nFROM kibana_sample_data_flights\"\n| math \"total_hours\"\n| formatNumber \"00\"\n| metric\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-2b890a9d-2f4d-4c4d-8275-ac371190d486",
- "position": {
- "left": 173.25,
- "top": 232.000363384436,
- "width": 81,
- "height": 39,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"DAYS\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-b253908c-b8bd-4ea1-a35f-eae5eb1ae63a",
- "position": {
- "left": 26,
- "top": 179.750363384436,
- "width": 375.5,
- "height": 65,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT FLOOR(SUM(FlightTimeMin)/1440) as total_days\nFROM kibana_sample_data_flights\"\n| math \"total_days\"\n| formatNumber \"00a\"\n| metric\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-9fb07d44-c181-4d03-a431-492d1977a79c",
- "position": {
- "left": 26,
- "top": 550.750363384436,
- "width": 375.5,
- "height": 54,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT ((SUM(FlightTimeMin) % 1440) / 60 ) as total_minutes\nFROM kibana_sample_data_flights\"\n| math \"total_minutes\"\n| formatNumber \"00\"\n| metric\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-60733afe-abce-4449-b0dd-5310d8ffffce",
- "position": {
- "left": 163.75,
- "top": 416.9379542305451,
- "width": 100,
- "height": 39,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"HOURS\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-b7f3b9e3-2cb2-49e7-8768-b41afe0b49b1",
- "position": {
- "left": 173.25,
- "top": 599.750363384436,
- "width": 81,
- "height": 39,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"MINS\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"center\" color=\"#48A8E0\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-526d29d1-8d5e-4c15-a5c2-fa23edf580ac",
- "position": {
- "left": 423.5251242870414,
- "top": 185.312409153891,
- "width": 407,
- "height": 140.250363384436,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-1d11f5a4-95a3-4a50-9191-6beb61bb8fbc",
- "position": {
- "left": 855.5,
- "top": 343.687590846109,
- "width": 407,
- "height": 140.250363384436,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-cfe6524e-b201-439a-974c-037406b760f6",
- "position": {
- "left": 616.5251242870414,
- "top": 50.5,
- "width": 187,
- "height": 99,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql query=\"SELECT COUNT(*) as total_flights\nFROM kibana_sample_data_flights\"\n| math \"total_flights\"\n| formatNumber \"0a]\"\n| metric \"FLIGHTS\"\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=60 align=\"right\" color=\"#4184A5\" weight=\"normal\" underline=false italic=false}\nlabelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"right\" color=\"#4184A5\" weight=\"normal\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-e162c0b4-9393-43f9-8324-0263f40b4b85",
- "position": {
- "left": 439.52512428704136,
- "top": 40.687590846109,
- "width": 78.47487571295858,
- "height": 59.312409153891,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-520a03a1-f522-4a18-ad4a-b84e87e4dc44\"}\n| render\n"
- },
- {
- "id": "element-0c37705e-004f-49c6-abda-9847b762c9f2",
- "position": {
- "left": 603.5251242870414,
- "top": 211.84415880749054,
- "width": 200,
- "height": 100,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT MIN(DistanceMiles) as min_distance\nFROM kibana_sample_data_flights\nWHERE DistanceMiles > 0\"\n| math \"min_distance\"\n| formatNumber \"00.0a\"\n| metric \"MILES\"\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=60 align=\"right\" color=\"#7EA030\" weight=\"normal\" underline=false italic=false}\nlabelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"right\" color=\"#7EA030\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-dd0f8a2e-1142-4140-bedb-913cae044204",
- "position": {
- "left": 439.52512428704136,
- "top": 205.68795423054502,
- "width": 78.47487571295858,
- "height": 45.812409153891,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-08aa2e8f-6c3b-428f-82de-581004292cf0\"}\n| render\n"
- },
- {
- "id": "element-a81c83c7-8b61-4a1f-8da5-3270821c0089",
- "position": {
- "left": 435,
- "top": 267.875181692218,
- "width": 237,
- "height": 30.5,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"SHORTEST FLIGHT\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"left\" color=\"#7EA030\" weight=\"normal\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-79393fba-8da9-4884-a280-e2a87e163f1a",
- "position": {
- "left": 870.7876864305622,
- "top": 40.687590846109,
- "width": 78.47487571295858,
- "height": 59.312409153891,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-11a8022c-c1ac-4bbd-857a-db95fb8ca452\"}\n| render\n"
- },
- {
- "id": "element-ec914936-fc84-4915-82f7-1ca6b37ddc03",
- "position": {
- "left": 870.7876864305622,
- "top": 262.500363384436,
- "width": 237,
- "height": 30.5,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| demodata\n| markdown \"LONGEST FLIGHT\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"left\" color=\"#EFB341\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-8aae2d27-7a8c-4851-9b9c-a66e5b1dda9f",
- "position": {
- "left": 870.7876864305622,
- "top": 198.93795423054502,
- "width": 78.47487571295858,
- "height": 59.312409153891,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-e73f53c5-fdcc-4232-bd6f-85a06281cf6c\"}\n| render\n",
- "filter": null
- },
- {
- "id": "element-bca09809-6f73-4363-9732-5c86bb28f2f9",
- "position": {
- "left": 423.5251242870414,
- "top": 343.687590846109,
- "width": 407,
- "height": 140.250363384436,
- "angle": 0
- },
- "expression": "\nshape \"square\" fill=\"#FFFFFF\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-b6e7d5e1-3221-4274-ac97-5e0387d090c0",
- "position": {
- "left": 1033.5,
- "top": 365.46897711527254,
- "width": 200,
- "height": 96.687590846109,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT COUNT(*) as total_cancellations\nFROM kibana_sample_data_flights\nWHERE Cancelled = true\"\n| math \"total_cancellations\"\n| formatNumber \"0a\"\n| metric \"CANCELLATIONS\"\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=60 align=\"right\" color=\"#D88734\" weight=\"normal\" underline=false italic=false}\nlabelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"right\" color=\"#D88734\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-7ac04e37-e7aa-42cf-9afe-314ebd6de9d6",
- "position": {
- "left": 870.7876864305622,
- "top": 364.4379542305451,
- "width": 78.47487571295858,
- "height": 59.312409153891,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-63a49130-fb96-4576-ac31-d86c934234d1\"}\n| render\n",
- "filter": null
- },
- {
- "id": "element-0cf4194e-d460-40a1-a023-775f1946eb16",
- "position": {
- "left": 600.5251242870414,
- "top": 364.4379542305451,
- "width": 206,
- "height": 105,
- "angle": 0
- },
- "expression": "\nkibana\n| selectFilter\n| essql\nquery=\"SELECT COUNT(DISTINCT OriginCountry) as total_countries\nFROM kibana_sample_data_flights\"\n| math \"total_countries\"\n| metric \"COUNTRIES\"\nmetricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=60 align=\"right\" color=\"#CB3072\" weight=\"normal\" underline=false italic=false}\nlabelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=24 align=\"right\" color=\"#CB3072\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-41734b58-e7aa-4888-980c-677420b1c736",
- "position": {
- "left": 439.52512428704136,
- "top": 362.06277253832695,
- "width": 78.47487571295858,
- "height": 59.312409153891,
- "angle": 0
- },
- "expression": "\nimage mode=\"contain\" dataurl={asset \"asset-4843e3bb-6cb0-43b7-b076-deea9a901fc6\"}\n| render\n",
- "filter": null
- }
- ]
- }
- ],
- "colors": [
- "#37988d",
- "#c19628",
- "#b83c6f",
- "#3f9939",
- "#1785b0",
- "#ca5f35",
- "#45bdb0",
- "#f2bc33",
- "#e74b8b",
- "#4fbf48",
- "#1ea6dc",
- "#fd7643",
- "#72cec3",
- "#f5cc5d",
- "#ec77a8",
- "#7acf74",
- "#4cbce4",
- "#fd986f",
- "#a1ded7",
- "#f8dd91",
- "#f2a4c5",
- "#a6dfa2",
- "#86d2ed",
- "#fdba9f",
- "#000000",
- "#444444",
- "#777777",
- "#BBBBBB",
- "rgba(255,255,255,0)"
- ],
- "@timestamp": "2018-10-31T17:32:39.068Z",
- "@created": "2018-10-31T17:25:59.027Z",
- "assets": {
- "asset-2da3aba1-6e0f-4a79-879e-0ab3cfa170d6": {
- "id": "asset-2da3aba1-6e0f-4a79-879e-0ab3cfa170d6",
- "@created": "2018-10-13T16:17:38.860Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-9e41d208-ec45-472d-a118-e2e2c811291b": {
- "id": "asset-9e41d208-ec45-472d-a118-e2e2c811291b",
- "@created": "2018-10-13T16:33:38.197Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-520a03a1-f522-4a18-ad4a-b84e87e4dc44": {
- "id": "asset-520a03a1-f522-4a18-ad4a-b84e87e4dc44",
- "@created": "2018-10-13T16:39:42.089Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-08aa2e8f-6c3b-428f-82de-581004292cf0": {
- "id": "asset-08aa2e8f-6c3b-428f-82de-581004292cf0",
- "@created": "2018-10-13T16:42:03.959Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-11a8022c-c1ac-4bbd-857a-db95fb8ca452": {
- "id": "asset-11a8022c-c1ac-4bbd-857a-db95fb8ca452",
- "@created": "2018-10-13T16:44:44.648Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-e73f53c5-fdcc-4232-bd6f-85a06281cf6c": {
- "id": "asset-e73f53c5-fdcc-4232-bd6f-85a06281cf6c",
- "@created": "2018-10-13T16:49:36.056Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-63a49130-fb96-4576-ac31-d86c934234d1": {
- "id": "asset-63a49130-fb96-4576-ac31-d86c934234d1",
- "@created": "2018-10-13T16:51:32.983Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-4843e3bb-6cb0-43b7-b076-deea9a901fc6": {
- "id": "asset-4843e3bb-6cb0-43b7-b076-deea9a901fc6",
- "@created": "2018-10-13T16:52:44.303Z",
- "type": "dataurl",
- "value": ""
- }
- }
- }
- }
-]
diff --git a/x-pack/plugins/canvas/server/sample_data/index.ts b/x-pack/plugins/canvas/server/sample_data/index.ts
deleted file mode 100644
index 1cbb1d0aaee6a..0000000000000
--- a/x-pack/plugins/canvas/server/sample_data/index.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-// @ts-ignore this file is too large for TypeScript, so it is excluded from our project config
-import ecommerceSavedObjects from './ecommerce_saved_objects.json';
-// @ts-ignore this file is too large for TypeScript, so it is excluded from our project config
-import flightsSavedObjects from './flights_saved_objects.json';
-// @ts-ignore this file is too large for TypeScript, so it is excluded from our project config
-import webLogsSavedObjects from './web_logs_saved_objects.json';
-import { loadSampleData } from './load_sample_data';
-
-export { loadSampleData, ecommerceSavedObjects, flightsSavedObjects, webLogsSavedObjects };
diff --git a/x-pack/plugins/canvas/server/sample_data/load_sample_data.ts b/x-pack/plugins/canvas/server/sample_data/load_sample_data.ts
deleted file mode 100644
index da219146a3609..0000000000000
--- a/x-pack/plugins/canvas/server/sample_data/load_sample_data.ts
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import { SampleDataRegistrySetup } from '@kbn/home-plugin/server';
-import { CANVAS as label } from '../../i18n';
-import { ecommerceSavedObjects, flightsSavedObjects, webLogsSavedObjects } from '.';
-
-export function loadSampleData(
- addSavedObjectsToSampleDataset: SampleDataRegistrySetup['addSavedObjectsToSampleDataset'],
- addAppLinksToSampleDataset: SampleDataRegistrySetup['addAppLinksToSampleDataset']
-) {
- const now = new Date();
- const nowTimestamp = now.toISOString();
-
- // @ts-expect-error: untyped local
- function updateCanvasWorkpadTimestamps(savedObjects) {
- // @ts-expect-error: untyped local
- return savedObjects.map((savedObject) => {
- if (savedObject.type === 'canvas-workpad') {
- savedObject.attributes['@timestamp'] = nowTimestamp;
- savedObject.attributes['@created'] = nowTimestamp;
- }
-
- return savedObject;
- });
- }
- const getPath = (objectId: string) => `/app/canvas#/workpad/${objectId}`;
-
- addSavedObjectsToSampleDataset('ecommerce', updateCanvasWorkpadTimestamps(ecommerceSavedObjects));
- addAppLinksToSampleDataset('ecommerce', [
- {
- sampleObject: {
- type: 'canvas-workpad',
- id: 'workpad-e08b9bdb-ec14-4339-94c4-063bddfd610e',
- },
- getPath,
- icon: 'canvasApp',
- label,
- },
- ]);
-
- addSavedObjectsToSampleDataset('flights', updateCanvasWorkpadTimestamps(flightsSavedObjects));
- addAppLinksToSampleDataset('flights', [
- {
- sampleObject: {
- type: 'canvas-workpad',
- id: 'workpad-a474e74b-aedc-47c3-894a-db77e62c41e0',
- },
- getPath,
- icon: 'canvasApp',
- label,
- },
- ]);
-
- addSavedObjectsToSampleDataset('logs', updateCanvasWorkpadTimestamps(webLogsSavedObjects));
- addAppLinksToSampleDataset('logs', [
- {
- sampleObject: {
- type: 'canvas-workpad',
- id: 'workpad-ad72a4e9-b422-480c-be6d-a64a0b79541d',
- },
- getPath,
- icon: 'canvasApp',
- label,
- },
- ]);
-}
diff --git a/x-pack/plugins/canvas/server/sample_data/web_logs_saved_objects.json b/x-pack/plugins/canvas/server/sample_data/web_logs_saved_objects.json
deleted file mode 100644
index 8c49935a4514d..0000000000000
--- a/x-pack/plugins/canvas/server/sample_data/web_logs_saved_objects.json
+++ /dev/null
@@ -1,757 +0,0 @@
-[
- {
- "id": "workpad-ad72a4e9-b422-480c-be6d-a64a0b79541d",
- "type": "canvas-workpad",
- "updated_at": "2018-10-22T12:41:57.071Z",
- "version": 1,
- "migrationVersion": {
- "canvas-workpad": "7.0.0"
- },
- "attributes": {
- "name": "[Logs] Web Traffic",
- "width": 1280,
- "height": 720,
- "page": 0,
- "pages": [
- {
- "id": "page-e125ca0b-f6b2-437c-bc4c-918c468fbd9f",
- "style": {
- "background": "#000000"
- },
- "transition": {
- "name": ""
- },
- "elements": [
- {
- "id": "element-950e478d-39be-4630-9ebe-d46578951025",
- "position": {
- "left": 249,
- "top": 574.3671875,
- "width": 1013.5,
- "height": 131.2578125,
- "angle": 0
- },
- "expression": "shape \"square\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-f6d67bd9-7edf-4a4c-944e-019eb2a89e46",
- "position": {
- "left": 249,
- "top": 426.5,
- "width": 1013.5,
- "height": 131.2578125,
- "angle": 0
- },
- "expression": "shape \"square\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-fa296ebc-3ede-44f1-a027-f9aa0a8ba58b",
- "position": {
- "left": 249,
- "top": 275.87109375,
- "width": 1013.5,
- "height": 131.2578125,
- "angle": 0
- },
- "expression": "shape \"square\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-21844047-2818-4071-bb9b-59cc68139c5f",
- "position": {
- "left": 589,
- "top": 110.7578125,
- "width": 318,
- "height": 148.3046875,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#414143\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-a2136689-36d7-4f61-a9c7-5e4e3c89f2ca",
- "position": {
- "left": 924.5,
- "top": 109.28515625,
- "width": 318,
- "height": 148.3046875,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#414143\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-2e02449b-433e-47c4-84ab-6f702619e21a",
- "position": {
- "left": 249,
- "top": 109.6328125,
- "width": 318,
- "height": 148.3046875,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#414143\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-0f10bedf-728c-4207-96b8-bbb3021a91f1",
- "position": {
- "left": 245,
- "top": 12,
- "width": 1017.5,
- "height": 65.90625,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#221F20\" border=\"#777777\" borderWidth=0 maintainAspect=false\n| render\n",
- "filter": null
- },
- {
- "id": "element-4130544d-054a-4600-928a-39f1423788c6",
- "position": {
- "left": 13.5,
- "top": 12,
- "width": 211,
- "height": 693.625,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#221F20\" border=\"#777777\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-57ffa8a7-f3f3-45bf-a35a-025a7647b8e7",
- "position": {
- "left": 19.25,
- "top": 88.5625,
- "width": 109,
- "height": 7.25,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#CFD0D2\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-4562db88-edbe-45b2-86aa-c549f2e25c98",
- "position": {
- "left": 671.5,
- "top": 303.2421875,
- "width": 574,
- "height": 89.13671875,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#221F20\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-6556fa13-4557-47bc-bb9f-08a525604e13",
- "position": {
- "left": 56.25,
- "top": 13.625,
- "width": 168.25,
- "height": 149,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#221F20\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-671589a9-54b6-46a1-b5e7-363b9d539795",
- "position": {
- "left": 258,
- "top": 24.8125,
- "width": 28,
- "height": 36,
- "angle": 0
- },
- "expression": "filters \n| essql\n query=\"SELECT host, response.keyword AS response\n FROM kibana_sample_data_logs\n WHERE host='artifacts.elastic.co'\n ORDER BY timestamp DESC\n LIMIT 1\"\n| alterColumn \"response\" type=\"number\" \n| getCell \"response\" \n| image mode=\"contain\" \n dataurl={\n asset {\n if {compare lt to=400} \n then=\"asset-0a807073-d056-4c7b-9bf4-225b71e47243\" \n else=\"asset-1343672d-7c02-4402-929e-0f8fef69cddd\"\n }\n } \n| render\n"
- },
- {
- "id": "element-d98c4bb0-f9ae-4e4a-838d-572b6919a3a2",
- "position": {
- "left": 20.375,
- "top": 68,
- "width": 60.25,
- "height": 27.8125,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"5XX\"\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=18 align=\"left\" color=\"#CFD0D2\" weight=\"normal\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-11de34da-7783-4d09-b22f-4ec1f8c957ea",
- "position": {
- "left": 573,
- "top": 459.5,
- "width": 79,
- "height": 82,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT SUM(bytes) as total_bytes, host\n FROM kibana_sample_data_logs\n GROUP BY host\"\n| pointseries color=\"host\" size=\"total_bytes\"\n| pie hole=60 labels=false legend=false palette={palette \"#346822\" \"#57993F\" \"#C3F99C\" \"#6CBD38\" gradient=true}\n| render\n"
- },
- {
- "id": "element-a2e808f6-1b2e-4f84-931e-6c38424c5480",
- "position": {
- "left": 289.5,
- "top": 29.4375,
- "width": 165,
- "height": 26.75,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT host\n FROM kibana_sample_data_logs\n WHERE host='artifacts.elastic.co'\n ORDER BY timestamp DESC\n LIMIT 1\"\n| markdown {getCell \"host\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=12 align=\"left\" color=\"#CFD0D2\" size=18 weight=\"lighter\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-bc35a3fe-c896-4898-a7f3-e5778958d6b0",
- "position": {
- "left": 265,
- "top": 436.25,
- "width": 302,
- "height": 110,
- "angle": 0,
- "parent": null
- },
- "expression": "kibana\n| selectFilter\n| essql \n query=\"SELECT SUM(bytes) as total_bytes\n FROM kibana_sample_data_logs\"\n| math \"total_bytes\"\n| formatNumber \"0.00b\"\n| metric \"BYTES TRANSFERRED\"\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"left\" color=\"#FFFFFF\" weight=\"normal\" underline=false italic=false}\n labelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=30 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-a684991f-f179-4fcc-b474-5ed71b0a6f3e",
- "position": {
- "left": 264.5,
- "top": 586.5,
- "width": 290.5,
- "height": 104,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql \n query=\"SELECT COUNT(timestamp) as total_visitors\n FROM kibana_sample_data_logs\"\n| math \"total_visitors\"\n| metric \"TOTAL VISITORS\"\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"left\" color=\"#FFFFFF\" weight=\"normal\" underline=false italic=false}\n labelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=30 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-a8a8fa93-8e08-4e9f-b3e4-f4014543fe1f",
- "position": {
- "left": 515.5,
- "top": 29.4375,
- "width": 147,
- "height": 25.75,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql \n query=\"SELECT host\n FROM kibana_sample_data_logs\n WHERE host='www.elastic.co'\"\n| markdown {getCell \"host\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=12 align=\"left\" color=\"#CFD0D2\" size=18 weight=\"lighter\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-38b281b2-ab5e-41ee-aa3e-e48bc3f778df",
- "position": {
- "left": 719,
- "top": 28.625,
- "width": 247,
- "height": 26.75,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT host \n FROM kibana_sample_data_logs\n WHERE host='cdn.elastic-elastic-elastic.org'\"\n| markdown {getCell \"host\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=12 align=\"left\" color=\"#CFD0D2\" size=18 weight=\"lighter\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-b481bf28-15d3-4f0b-b67b-e268c68bfe9c",
- "position": {
- "left": 1040.5,
- "top": 28.8125,
- "width": 209,
- "height": 27.375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT host\n FROM kibana_sample_data_logs\n WHERE host='elastic-elastic-elastic.org'\"\n| markdown {getCell \"host\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=12 align=\"left\" color=\"#CFD0D2\" size=18 weight=\"lighter\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-ebb18e7a-ec51-4072-8453-58fbb883584b",
- "position": {
- "left": 677.5,
- "top": 451.77734375,
- "width": 578,
- "height": 90.5,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT SUM(bytes) as total_bytes, HOUR_OF_DAY(timestamp) as hour, host\n FROM kibana_sample_data_logs\n GROUP BY host, HOUR_OF_DAY(timestamp)\n ORDER BY HOUR_OF_DAY(timestamp) DESC\"\n| pointseries x=\"hour\" y=\"total_bytes\" color=\"host\"\n| plot defaultStyle={seriesStyle bars=0 lines=3 points=0} legend=false xaxis=false yaxis=false palette={palette \"#346822\" \"#57993F\" \"#C3F99C\" \"#6CBD38\" gradient=true}\n| render containerStyle={containerStyle backgroundColor=\"#221F20\"}\n"
- },
- {
- "id": "element-05a065b5-5f01-4502-9f91-fdfc3de1b456",
- "position": {
- "left": 677.5,
- "top": 594.875,
- "width": 578,
- "height": 87.25,
- "angle": 0,
- "parent": null
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(timestamp) as total_visitors, HOUR_OF_DAY(timestamp) as hour, host\n FROM kibana_sample_data_logs\n GROUP BY host, HOUR_OF_DAY(timestamp)\n ORDER BY HOUR_OF_DAY(timestamp) DESC\"\n| pointseries x=\"hour\" y=\"total_visitors\" color=\"host\"\n| plot defaultStyle={seriesStyle bars=0 lines=3 points=0} legend=false xaxis=false yaxis=false palette={palette \"#C83C5C\" \"#D56F79\" \"#F6C4C5\" \"#F1A3A6\" gradient=true}\n| render containerStyle={containerStyle backgroundColor=\"#221F20\"}\n"
- },
- {
- "id": "element-ce1da927-2d4f-413e-85e9-4fd1106b5207",
- "position": {
- "left": 573,
- "top": 604.5,
- "width": 79,
- "height": 82,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(timestamp) as total_visitors, host\n FROM kibana_sample_data_logs\n GROUP BY host\"\n| pointseries color=\"host\" size=\"total_visitors\"\n| pie hole=60 labels=false legend=false palette={palette \"#C83C5C\" \"#D56F79\" \"#F6C4C5\" \"#F1A3A6\" gradient=true}\n| render\n",
- "filter": null
- },
- {
- "id": "element-acccadaf-3ce8-4ca6-8205-4529d42c1eef",
- "position": {
- "left": 677,
- "top": 290.62109375,
- "width": 562,
- "height": 101.7578125,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\nquery=\"SELECT COUNT(timestamp) as total_errors, timestamp\nFROM kibana_sample_data_logs\nWHERE tags LIKE '%warning%'\nGROUP BY timestamp\nORDER BY timestamp DESC\"\n| pointseries x=\"timestamp\" y=\"total_errors\"\n| plot defaultStyle={seriesStyle bars=\"1\" lines=\"0\" points=0 color=\"#E9782F\"} legend=false xaxis=false yaxis=false\n| render\n"
- },
- {
- "id": "element-1ae8ea70-993a-4503-916a-ce98717054f6",
- "position": {
- "left": 680.5,
- "top": 290.62109375,
- "width": 562,
- "height": 101.7578125,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(timestamp) as total_errors, timestamp\n FROM kibana_sample_data_logs\n WHERE tags LIKE '%error%'\n GROUP BY timestamp\n ORDER BY timestamp DESC\"\n| pointseries x=\"timestamp\" y=\"total_errors\"\n| plot defaultStyle={seriesStyle bars=\"1\" lines=\"0\" points=0 color=\"#F2C242\"} legend=false xaxis=false yaxis=false\n| render\n"
- },
- {
- "id": "element-70a2bca6-de31-4bee-81b1-b18528820645",
- "position": {
- "left": 264.5,
- "top": 287.4375,
- "width": 215,
- "height": 104.94140625,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(timestamp) as total_errors\n FROM kibana_sample_data_logs\n WHERE tags LIKE '%warning%' OR tags LIKE '%error%'\"\n| math \"total_errors\"\n| metric \"TOTAL ISSUES\"\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"left\" color=\"#FFFFFF\" weight=\"normal\" underline=false italic=false}\n labelFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=30 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-5b36cc1b-e0d6-4ddc-bf16-849fc41e1f16",
- "position": {
- "left": 562.5,
- "top": 294.1953125,
- "width": 100,
- "height": 98.18359375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(timestamp) as total_errors\n FROM kibana_sample_data_logs\n WHERE tags LIKE '%warning%' OR tags LIKE '%error%'\"\n| math \"clamp(sum(total_errors / 100),0,1)\"\n| revealImage origin=\"bottom\" image={asset \"asset-a1e77720-eb0b-42a0-a1c0-a159035e4f26\"} emptyImage={asset \"asset-d2cca77f-ba40-4acb-beff-38fab19c7b65\"}\n| render\n"
- },
- {
- "id": "element-9d5e9c4b-a7f5-459b-ab15-cfcd1d1d00c9",
- "position": {
- "left": 319.5,
- "top": 120.17578125,
- "width": 239,
- "height": 39.68359375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"MACHINE\"\nfont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=30 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-d575ce4e-4aa5-4c54-993a-ca56890e434f",
- "position": {
- "left": 259.5,
- "top": 171.69140625,
- "width": 295.5,
- "height": 80.12109375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| esdocs index=\"kibana_sample_data_logs\" sort=\"timestamp, desc\" fields=\"machine.os, machine.ram\" count=1\n| markdown \"**OS:** \" {getCell \"machine.os\"} \"\\\n **RAM:** \" {getCell \"machine.ram\" | formatNumber \"00.0b\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=20 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render containerStyle={containerStyle padding=\"5px\"}\n"
- },
- {
- "id": "element-6f777a39-f934-4263-94ea-4f1d48f3849c",
- "position": {
- "left": 604.75,
- "top": 171.69140625,
- "width": 298,
- "height": 83.74609375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| esdocs index=\"kibana_sample_data_logs\" sort=\"timestamp, desc\" fields=\"request\" count=1\n| markdown {getCell \"request\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=20 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render containerStyle={containerStyle padding=\"5px\"}\n"
- },
- {
- "id": "element-7bfcdb0f-3533-4e50-a94a-f0487f374bff",
- "position": {
- "left": 941.5,
- "top": 171.69140625,
- "width": 284,
- "height": 80.12109375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| esdocs index=\"kibana_sample_data_logs\" sort=\"timestamp, desc\" fields=\"geo.src, geo.dest\" count=1\n| markdown \"**ORIGIN COUNTRY:** \" {getCell \"geo.src\"} \"\\\n **DESTINATION:** \" {getCell \"geo.dest\"}\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=20 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render containerStyle={containerStyle padding=\"5px\"}\n"
- },
- {
- "id": "element-db2d0540-f734-421e-a9a5-7f6e9eef0bd7",
- "position": {
- "left": 987.5,
- "top": -51,
- "width": 285,
- "height": 50,
- "angle": 0,
- "parent": null
- },
- "expression": "timefilterControl compact=true column=\"timestamp\"\n| render\n",
- "filter": "timefilter from=\"now-24h\" to=now column=timestamp"
- },
- {
- "id": "element-a29b5f31-3204-4174-a511-5869648ccae0",
- "position": {
- "left": 73.75,
- "top": 34.2578125,
- "width": 133.25,
- "height": 108.609375,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#C83C5B\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-c509ce21-e729-4aa5-b892-f4be441cde26",
- "position": {
- "left": 94.875,
- "top": 64,
- "width": 91,
- "height": 49.125,
- "angle": 0
- },
- "expression": "filters \n| essql \n query=\"SELECT COUNT(*) as response_code\n FROM kibana_sample_data_logs\n WHERE response >= 500\"\n| math \"response_code\"\n| metric\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#FFFFFF\" weight=\"bold\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-d27ad090-4e58-4d9c-aef7-ccb8ca043758",
- "position": {
- "left": 20.375,
- "top": 612.625,
- "width": 109,
- "height": 7.25,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#CFD0D2\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-99baa692-12dc-4d8d-9d78-05cb1aa7f7a8",
- "position": {
- "left": 21.1875,
- "top": 436.25,
- "width": 109,
- "height": 7.25,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#CFD0D2\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-f0412810-61fb-4ab8-ba9f-a69ba344d4d7",
- "position": {
- "left": 20.25,
- "top": 251.8125,
- "width": 109,
- "height": 7.25,
- "angle": 0
- },
- "expression": "shape \"square\" fill=\"#CFD0D2\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=false\n| render\n"
- },
- {
- "id": "element-42587f38-4f6e-4a23-9ade-d0f23449efba",
- "position": {
- "left": 56.25,
- "top": 183.4375,
- "width": 168.25,
- "height": 149,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#221F20\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-40d243ea-088c-4e17-b797-c47c8b94e282",
- "position": {
- "left": 56.25,
- "top": 369,
- "width": 168.25,
- "height": 149,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#221F20\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-349aaa30-c164-4b95-b5aa-891a43e7b693",
- "position": {
- "left": 56.25,
- "top": 541.5,
- "width": 168.25,
- "height": 149,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#221F20\" border=\"#CFD0D2\" borderWidth=2 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-e92c89d9-4ddd-499c-8367-94271da02b3d",
- "position": {
- "left": 73.75,
- "top": 203.6328125,
- "width": 133.25,
- "height": 108.609375,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#E9782F\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-f827824d-fc40-4905-937d-060e9748acce",
- "position": {
- "left": 74.75,
- "top": 389.1953125,
- "width": 133.25,
- "height": 108.609375,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#F2C242\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-f7e459a0-613e-43f4-9ced-d5f4ae6f3c47",
- "position": {
- "left": 74.75,
- "top": 561.9453125,
- "width": 133.25,
- "height": 108.609375,
- "angle": 0
- },
- "expression": "shape \"circle\" fill=\"#6CBD38\" border=\"rgba(255,255,255,0)\" borderWidth=0 maintainAspect=true\n| render\n"
- },
- {
- "id": "element-f5760f24-d9cb-42e8-ae60-13c60335f049",
- "position": {
- "left": 21.1875,
- "top": 590.1875,
- "width": 61.375,
- "height": 25.8125,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"2XX\"\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=18 align=\"left\" color=\"#CFD0D2\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-5e9998b3-7c27-4f4a-8f61-6b857339e07e",
- "position": {
- "left": 21.1875,
- "top": 413.59375,
- "width": 50.625,
- "height": 26.28125,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"3XX\"\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=18 align=\"left\" color=\"#CFD0D2\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-744e0e58-e1be-4919-a9fb-eaa46c5d8aaa",
- "position": {
- "left": 19.25,
- "top": 228.4375,
- "width": 54.5,
- "height": 30.625,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"4XX\"\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=18 align=\"left\" color=\"#CFD0D2\" weight=\"normal\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-9f7bea99-8c0c-49b1-b8a3-9af26eb0466d",
- "position": {
- "left": 94.875,
- "top": 228.4375,
- "width": 91,
- "height": 59,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql \n query=\"SELECT COUNT(*) as response_code\n FROM kibana_sample_data_logs\n WHERE response >= 400 AND response < 500\"\n| math \"unique(response_code)\"\n| metric\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#FFFFFF\" weight=\"bold\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-607512ac-3d83-4d36-87c1-d5f13502f084",
- "position": {
- "left": 97.5,
- "top": 418.25,
- "width": 88.375,
- "height": 59,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(*) as response_code\n FROM kibana_sample_data_logs\n WHERE response >= 300 AND response < 400\"\n| math \"response_code\"\n| metric\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#FFFFFF\" weight=\"bold\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-3cc56225-d739-4279-97f2-5c179fb013a5",
- "position": {
- "left": 94.875,
- "top": 590.1875,
- "width": 91,
- "height": 59,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| essql\n query=\"SELECT COUNT(*) as response_code\n FROM kibana_sample_data_logs\n WHERE response >= 200 AND response < 300\"\n| math \"response_code\"\n| formatNumber \"0a\"\n| metric\n metricFont={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=48 align=\"center\" color=\"#FFFFFF\" weight=\"bold\" underline=false italic=false}\n| render\n"
- },
- {
- "id": "element-f7d5956f-287d-4ac6-bcfb-fca6f8ebe63e",
- "position": {
- "left": 479.5,
- "top": 24,
- "width": 28,
- "height": 36,
- "angle": 0
- },
- "expression": "filters \n| essql\n query=\"SELECT host, response.keyword AS response\n FROM kibana_sample_data_logs\n WHERE host='www.elastic.co'\n ORDER BY timestamp DESC\n LIMIT 1\"\n| alterColumn \"response\" type=\"number\" \n| image mode=\"contain\" \n dataurl={\n asset {\n if {getCell \"response\" | compare lt to=400} \n then=\"asset-0a807073-d056-4c7b-9bf4-225b71e47243\" \n else=\"asset-1343672d-7c02-4402-929e-0f8fef69cddd\"\n }\n } \n| render\n",
- "filter": null
- },
- {
- "id": "element-254cc607-c924-49f4-a7f7-737480b4a056",
- "position": {
- "left": 682.5,
- "top": 24.5,
- "width": 28,
- "height": 36,
- "angle": 0
- },
- "expression": "filters \n| essql\n query=\"SELECT host, response.keyword AS response\n FROM kibana_sample_data_logs\n WHERE host='cdn.elastic-elastic-elastic.org'\n ORDER BY timestamp DESC\n LIMIT 1\"\n| alterColumn \"response\" type=\"number\" \n| image mode=\"contain\" \n dataurl={\n asset {\n if {getCell \"response\" | compare lt to=400} then=\"asset-0a807073-d056-4c7b-9bf4-225b71e47243\" else=\"asset-1343672d-7c02-4402-929e-0f8fef69cddd\"\n }\n } \n| render\n",
- "filter": null
- },
- {
- "id": "element-96aa263d-8222-4adc-94ff-2277a1f55dff",
- "position": {
- "left": 1001.5,
- "top": 24,
- "width": 28,
- "height": 36,
- "angle": 0
- },
- "expression": "filters \n| essql\n query=\"SELECT host, response.keyword AS response\n FROM kibana_sample_data_logs\n WHERE host='elastic-elastic-elastic.org'\n ORDER BY timestamp DESC\n LIMIT 1\"\n| alterColumn \"response\" type=\"number\" \n| image mode=\"contain\" \n dataurl={\n asset {\n if {getCell \"response\" | compare lt to=400} then=\"asset-0a807073-d056-4c7b-9bf4-225b71e47243\" else=\"asset-1343672d-7c02-4402-929e-0f8fef69cddd\"\n }\n } \n| render\n",
- "filter": null
- },
- {
- "id": "element-618ced11-d0da-4603-ae0b-77a5bb35e6c4",
- "position": {
- "left": 263.25,
- "top": 128.658203125,
- "width": 45,
- "height": 28.25,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-e9118351-dcc5-4a27-a7fc-f15eb308999b\"}\n| render\n"
- },
- {
- "id": "element-0f3c5e51-24b8-421e-b151-0c0229f80550",
- "position": {
- "left": 658.5,
- "top": 119.525390625,
- "width": 220,
- "height": 37.3828125,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"REQUEST\"\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=30 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-98d5f63a-ef33-415a-a1ec-44a5564c239f",
- "position": {
- "left": 996.5,
- "top": 117.525390625,
- "width": 220,
- "height": 43.68359375,
- "angle": 0
- },
- "expression": "kibana\n| selectFilter\n| demodata\n| markdown \"GEO\"\n font={font family=\"'Open Sans', Helvetica, Arial, sans-serif\" size=30 align=\"left\" color=\"#FFFFFF\" weight=\"lighter\" underline=false italic=false}\n| render\n",
- "filter": null
- },
- {
- "id": "element-88f2579a-50af-4330-baaf-e751092588a3",
- "position": {
- "left": 604.75,
- "top": 129.30859375,
- "width": 45,
- "height": 28.25,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-c2128a19-e5ba-450c-99c0-a68abbdfa684\"}\n| render\n",
- "filter": null
- },
- {
- "id": "element-eed60428-2b80-4558-8bcc-40b516fa63d4",
- "position": {
- "left": 942.5,
- "top": 124.7421875,
- "width": 45,
- "height": 29.25,
- "angle": 0
- },
- "expression": "image mode=\"contain\" dataurl={asset \"asset-86622ebc-32db-40fa-8310-262c85a10979\"}\n| render\n",
- "filter": null
- }
- ],
- "groups": []
- }
- ],
- "colors": [
- "#37988d",
- "#c19628",
- "#b83c6f",
- "#3f9939",
- "#1785b0",
- "#ca5f35",
- "#45bdb0",
- "#f2bc33",
- "#e74b8b",
- "#4fbf48",
- "#1ea6dc",
- "#fd7643",
- "#72cec3",
- "#f5cc5d",
- "#ec77a8",
- "#7acf74",
- "#4cbce4",
- "#fd986f",
- "#a1ded7",
- "#f8dd91",
- "#f2a4c5",
- "#a6dfa2",
- "#86d2ed",
- "#fdba9f",
- "#000000",
- "#444444",
- "#777777",
- "#BBBBBB",
- "#FFFFFF",
- "rgba(255,255,255,0)"
- ],
- "@timestamp": "2019-06-03T20:54:03.958Z",
- "@created": "2019-06-03T20:46:16.137Z",
- "assets": {
- "asset-a1e77720-eb0b-42a0-a1c0-a159035e4f26": {
- "id": "asset-a1e77720-eb0b-42a0-a1c0-a159035e4f26",
- "@created": "2018-10-13T10:48:32.499Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-d2cca77f-ba40-4acb-beff-38fab19c7b65": {
- "id": "asset-d2cca77f-ba40-4acb-beff-38fab19c7b65",
- "@created": "2018-10-13T10:48:37.615Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-1343672d-7c02-4402-929e-0f8fef69cddd": {
- "id": "asset-1343672d-7c02-4402-929e-0f8fef69cddd",
- "@created": "2018-10-13T14:50:42.520Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-0a807073-d056-4c7b-9bf4-225b71e47243": {
- "id": "asset-0a807073-d056-4c7b-9bf4-225b71e47243",
- "@created": "2018-10-13T14:50:49.318Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-86622ebc-32db-40fa-8310-262c85a10979": {
- "id": "asset-86622ebc-32db-40fa-8310-262c85a10979",
- "@created": "2018-10-13T15:01:15.036Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-c2128a19-e5ba-450c-99c0-a68abbdfa684": {
- "id": "asset-c2128a19-e5ba-450c-99c0-a68abbdfa684",
- "@created": "2018-10-13T15:02:05.173Z",
- "type": "dataurl",
- "value": ""
- },
- "asset-e9118351-dcc5-4a27-a7fc-f15eb308999b": {
- "id": "asset-e9118351-dcc5-4a27-a7fc-f15eb308999b",
- "@created": "2018-10-13T15:02:24.299Z",
- "type": "dataurl",
- "value": ""
- }
- },
- "css": ".canvasPage {\n\n}"
- }
- }
-]
\ No newline at end of file
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.test.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.test.ts
new file mode 100644
index 0000000000000..fa26fb68289a6
--- /dev/null
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.test.ts
@@ -0,0 +1,454 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import type { ElasticsearchClient } from '@kbn/core/server';
+import moment from 'moment-timezone';
+
+import type {
+ FetchAvailableCatIndicesResponseRequired,
+ IndexSearchAggregationResponse,
+} from './fetch_available_indices';
+import { fetchAvailableIndices } from './fetch_available_indices';
+
+function getEsClientMock() {
+ return {
+ search: jest.fn().mockResolvedValue({
+ aggregations: {
+ index: {
+ buckets: [],
+ },
+ },
+ }),
+ cat: {
+ indices: jest.fn().mockResolvedValue([]),
+ },
+ } as unknown as ElasticsearchClient & {
+ cat: {
+ indices: jest.Mock>;
+ };
+ search: jest.Mock>;
+ };
+}
+
+// fixing timezone for both Date and moment
+// so when tests are run in different timezones, the results are consistent
+process.env.TZ = 'UTC';
+moment.tz.setDefault('UTC');
+
+const DAY_IN_MILLIS = 24 * 60 * 60 * 1000;
+
+// We assume that the dates are in UTC, because es is using UTC
+// It also diminishes difference date parsing by Date and moment constructors
+// in different timezones, i.e. short ISO format '2021-10-01' is parsed as local
+// date by moment and as UTC date by Date, whereas long ISO format '2021-10-01T00:00:00Z'
+// is parsed as UTC date by both
+const startDateString: string = '2021-10-01T00:00:00Z';
+const endDateString: string = '2021-10-07T00:00:00Z';
+
+const startDateMillis: number = new Date(startDateString).getTime();
+const endDateMillis: number = new Date(endDateString).getTime();
+
+describe('fetchAvailableIndices', () => {
+ afterEach(() => {
+ jest.clearAllMocks();
+ });
+
+ it('aggregate search given index by startDate and endDate', async () => {
+ const esClientMock = getEsClientMock();
+
+ await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(esClientMock.search).toHaveBeenCalledWith({
+ query: {
+ bool: {
+ filter: [
+ {
+ range: {
+ '@timestamp': {
+ format: 'strict_date_optional_time',
+ gte: startDateString,
+ lte: endDateString,
+ },
+ },
+ },
+ ],
+ must: [],
+ must_not: [],
+ should: [],
+ },
+ },
+ index: 'logs-*',
+ size: 0,
+ aggs: {
+ index: {
+ terms: {
+ field: '_index',
+ },
+ },
+ },
+ });
+ });
+
+ it('should call esClient.cat.indices for given index', async () => {
+ const esClientMock = getEsClientMock();
+
+ await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(esClientMock.cat.indices).toHaveBeenCalledWith({
+ index: 'logs-*',
+ format: 'json',
+ h: 'index,creation.date',
+ });
+ });
+
+ describe('when indices are created within the date range', () => {
+ it('returns indices within the date range', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.10.01',
+ 'creation.date': `${startDateMillis}`,
+ },
+ {
+ index: 'logs-2021.10.05',
+ 'creation.date': `${startDateMillis + 4 * DAY_IN_MILLIS}`,
+ },
+ {
+ index: 'logs-2021.09.30',
+ 'creation.date': `${startDateMillis - DAY_IN_MILLIS}`,
+ },
+ ]);
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual(['logs-2021.10.01', 'logs-2021.10.05']);
+
+ expect(esClientMock.cat.indices).toHaveBeenCalledWith({
+ index: 'logs-*',
+ format: 'json',
+ h: 'index,creation.date',
+ });
+ });
+ });
+
+ describe('when indices are outside the date range', () => {
+ it('returns an empty list', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.09.30',
+ 'creation.date': `${startDateMillis - DAY_IN_MILLIS}`,
+ },
+ {
+ index: 'logs-2021.10.08',
+ 'creation.date': `${endDateMillis + DAY_IN_MILLIS}`,
+ },
+ ]);
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual([]);
+ });
+ });
+
+ describe('when no indices match the index pattern', () => {
+ it('returns empty list', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([]);
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'nonexistent-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual([]);
+ });
+ });
+
+ describe('when indices have data in the date range', () => {
+ it('returns indices with data in the date range', async () => {
+ const esClientMock = getEsClientMock();
+
+ // esClient.cat.indices returns no indices
+ esClientMock.cat.indices.mockResolvedValue([]);
+
+ // esClient.search returns indices with data in the date range
+ esClientMock.search.mockResolvedValue({
+ aggregations: {
+ index: {
+ buckets: [
+ { key: 'logs-2021.10.02', doc_count: 100 },
+ { key: 'logs-2021.10.03', doc_count: 150 },
+ ],
+ },
+ },
+ });
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual(['logs-2021.10.02', 'logs-2021.10.03']);
+ });
+
+ it('combines indices from both methods without duplicates', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.10.01',
+ 'creation.date': `${startDateMillis}`,
+ },
+ {
+ index: 'logs-2021.10.03',
+ 'creation.date': `${startDateMillis + 2 * DAY_IN_MILLIS}`,
+ },
+ ]);
+
+ esClientMock.search.mockResolvedValue({
+ aggregations: {
+ index: {
+ buckets: [
+ { key: 'logs-2021.10.03', doc_count: 150 },
+ { key: 'logs-2021.10.04', doc_count: 200 },
+ ],
+ },
+ },
+ });
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual(['logs-2021.10.01', 'logs-2021.10.03', 'logs-2021.10.04']);
+ });
+ });
+
+ describe('edge cases for creation dates', () => {
+ it('includes indices with creation date exactly at startDate and endDate', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.10.01',
+ 'creation.date': `${startDateMillis}`,
+ },
+ {
+ index: 'logs-2021.10.07',
+ 'creation.date': `${endDateMillis}`,
+ },
+ ]);
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual(['logs-2021.10.01', 'logs-2021.10.07']);
+ });
+ });
+
+ describe('when esClient.search rejects', () => {
+ it('throws an error', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.search.mockRejectedValue(new Error('Elasticsearch search error'));
+
+ await expect(
+ fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ })
+ ).rejects.toThrow('Elasticsearch search error');
+ });
+ });
+
+ describe('when both esClient.cat.indices and esClient.search return empty', () => {
+ it('returns an empty list', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([]);
+ esClientMock.search.mockResolvedValue({
+ aggregations: {
+ index: {
+ buckets: [],
+ },
+ },
+ });
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual([]);
+ });
+ });
+
+ describe('when indices are returned with both methods and have duplicates', () => {
+ it('does not duplicate indices in the result', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.10.05',
+ 'creation.date': `${startDateMillis + 4 * DAY_IN_MILLIS}`,
+ },
+ ]);
+
+ esClientMock.search.mockResolvedValue({
+ aggregations: {
+ index: {
+ buckets: [{ key: 'logs-2021.10.05', doc_count: 100 }],
+ },
+ },
+ });
+
+ const result = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ });
+
+ expect(result).toEqual(['logs-2021.10.05']);
+ });
+ });
+
+ describe('given keyword dates', () => {
+ describe('given 7 days range', () => {
+ beforeEach(() => {
+ jest.useFakeTimers();
+ jest.setSystemTime(new Date('2021-10-07T00:00:00Z').getTime());
+ });
+
+ afterEach(() => {
+ jest.useRealTimers();
+ });
+
+ it('finds indices created within the date range', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.10.01',
+ 'creation.date': `${startDateMillis}`,
+ },
+ {
+ index: 'logs-2021.10.05',
+ 'creation.date': `${startDateMillis + 4 * DAY_IN_MILLIS}`,
+ },
+ ]);
+
+ const results = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: 'now-7d/d',
+ endDate: 'now/d',
+ });
+
+ expect(results).toEqual(['logs-2021.10.01', 'logs-2021.10.05']);
+ });
+
+ it('finds indices with end date rounded up to the end of the day', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockResolvedValue([
+ {
+ index: 'logs-2021.10.06',
+ 'creation.date': `${new Date('2021-10-06T23:59:59Z').getTime()}`,
+ },
+ ]);
+
+ const results = await fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: 'now-7d/d',
+ endDate: 'now-1d/d',
+ });
+
+ expect(results).toEqual(['logs-2021.10.06']);
+ });
+ });
+ });
+
+ describe('rejections', () => {
+ beforeEach(() => {
+ jest.spyOn(console, 'warn').mockImplementation(() => {});
+ });
+ afterEach(() => {
+ jest.restoreAllMocks();
+ });
+ describe('when esClient.cat.indices rejects', () => {
+ it('throws an error', async () => {
+ const esClientMock = getEsClientMock();
+
+ esClientMock.cat.indices.mockRejectedValue(new Error('Elasticsearch error'));
+
+ await expect(
+ fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: endDateString,
+ })
+ ).rejects.toThrow('Elasticsearch error');
+ });
+ });
+
+ describe('when startDate is invalid', () => {
+ it('throws an error', async () => {
+ const esClientMock = getEsClientMock();
+
+ await expect(
+ fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: 'invalid-date',
+ endDate: endDateString,
+ })
+ ).rejects.toThrow('Invalid date format: invalid-date');
+ });
+ });
+
+ describe('when endDate is invalid', () => {
+ it('throws an error', async () => {
+ const esClientMock = getEsClientMock();
+
+ await expect(
+ fetchAvailableIndices(esClientMock, {
+ indexPattern: 'logs-*',
+ startDate: startDateString,
+ endDate: 'invalid-date',
+ })
+ ).rejects.toThrow('Invalid date format: invalid-date');
+ });
+ });
+ });
+});
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.ts
index 584a261689113..32311f28d636a 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_available_indices.ts
@@ -4,18 +4,72 @@
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/
+
import type { ElasticsearchClient } from '@kbn/core/server';
+import type { CatIndicesIndicesRecord } from '@elastic/elasticsearch/lib/api/types';
+import dateMath from '@kbn/datemath';
+
import { getRequestBody } from '../helpers/get_available_indices';
+export type FetchAvailableCatIndicesResponseRequired = Array<
+ Required>
+>;
+
type AggregateName = 'index';
-interface Result {
+export interface IndexSearchAggregationResponse {
index: {
- buckets: Array<{ key: string }>;
- doc_count: number;
+ buckets: Array<{ key: string; doc_count: number }>;
};
}
-export const fetchAvailableIndices = (
+const getParsedDateMs = (dateStr: string, roundUp = false) => {
+ const date = dateMath.parse(dateStr, roundUp ? { roundUp: true } : undefined);
+ if (!date?.isValid()) {
+ throw new Error(`Invalid date format: ${dateStr}`);
+ }
+ return date.valueOf();
+};
+
+export const fetchAvailableIndices = async (
esClient: ElasticsearchClient,
params: { indexPattern: string; startDate: string; endDate: string }
-) => esClient.search(getRequestBody(params));
+): Promise => {
+ const { indexPattern, startDate, endDate } = params;
+
+ const startDateMs = getParsedDateMs(startDate);
+ const endDateMs = getParsedDateMs(endDate, true);
+
+ const indicesCats = (await esClient.cat.indices({
+ index: indexPattern,
+ format: 'json',
+ h: 'index,creation.date',
+ })) as FetchAvailableCatIndicesResponseRequired;
+
+ const indicesCatsInRange = indicesCats.filter((indexInfo) => {
+ const creationDateMs = parseInt(indexInfo['creation.date'], 10);
+ return creationDateMs >= startDateMs && creationDateMs <= endDateMs;
+ });
+
+ const timeSeriesIndicesWithDataInRangeSearchResult = await esClient.search<
+ AggregateName,
+ IndexSearchAggregationResponse
+ >(getRequestBody(params));
+
+ const timeSeriesIndicesWithDataInRange =
+ timeSeriesIndicesWithDataInRangeSearchResult.aggregations?.index.buckets.map(
+ (bucket) => bucket.key
+ ) || [];
+
+ // Combine indices from both sources removing duplicates
+ const resultingIndices = new Set();
+
+ for (const indicesCat of indicesCatsInRange) {
+ resultingIndices.add(indicesCat.index);
+ }
+
+ for (const timeSeriesIndex of timeSeriesIndicesWithDataInRange) {
+ resultingIndices.add(timeSeriesIndex);
+ }
+
+ return Array.from(resultingIndices);
+};
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_stats.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_stats.ts
index 536fd461c61c9..40fc59219342c 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_stats.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/lib/fetch_stats.ts
@@ -57,16 +57,16 @@ export const parseMeteringStats = (meteringStatsIndices: MeteringStatsIndex[]) =
}, {});
export const pickAvailableMeteringStats = (
- indicesBuckets: Array<{ key: string }>,
+ indicesBuckets: string[],
meteringStatsIndices: Record
) =>
- indicesBuckets.reduce((acc: Record, { key }: { key: string }) => {
- if (meteringStatsIndices?.[key]) {
- acc[key] = {
- name: meteringStatsIndices?.[key].name,
- num_docs: meteringStatsIndices?.[key].num_docs,
+ indicesBuckets.reduce((acc: Record, indexName: string) => {
+ if (meteringStatsIndices?.[indexName]) {
+ acc[indexName] = {
+ name: meteringStatsIndices?.[indexName].name,
+ num_docs: meteringStatsIndices?.[indexName].num_docs,
size_in_bytes: null, // We don't have size_in_bytes intentionally when ILM is not available
- data_stream: meteringStatsIndices?.[key].data_stream,
+ data_stream: meteringStatsIndices?.[indexName].data_stream,
};
}
return acc;
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_ilm_explain.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_ilm_explain.ts
index 31202adffed2c..ee413ea09ef67 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_ilm_explain.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_ilm_explain.ts
@@ -19,7 +19,11 @@ export const getILMExplainRoute = (router: IRouter, logger: Logger) => {
.get({
path: GET_ILM_EXPLAIN,
access: 'internal',
- options: { tags: ['access:securitySolution'] },
+ security: {
+ authz: {
+ requiredPrivileges: ['securitySolution'],
+ },
+ },
})
.addVersion(
{
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_mappings.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_mappings.ts
index f3c59ccf9f3e2..845e118bc6f05 100755
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_mappings.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_mappings.ts
@@ -19,7 +19,11 @@ export const getIndexMappingsRoute = (router: IRouter, logger: Logger) => {
.get({
path: GET_INDEX_MAPPINGS,
access: 'internal',
- options: { tags: ['access:securitySolution'] },
+ security: {
+ authz: {
+ requiredPrivileges: ['securitySolution'],
+ },
+ },
})
.addVersion(
{
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.test.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.test.ts
index f3ff5ec256ad6..91996a4ab9f89 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.test.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.test.ts
@@ -152,17 +152,7 @@ describe('getIndexStatsRoute route', () => {
},
};
(fetchMeteringStats as jest.Mock).mockResolvedValue(mockMeteringStatsIndex);
- (fetchAvailableIndices as jest.Mock).mockResolvedValue({
- aggregations: {
- index: {
- buckets: [
- {
- key: 'my-index-000001',
- },
- ],
- },
- },
- });
+ (fetchAvailableIndices as jest.Mock).mockResolvedValue(['my-index-000001']);
const response = await server.inject(request, requestContextMock.convertContext(context));
expect(response.status).toEqual(200);
@@ -198,7 +188,7 @@ describe('getIndexStatsRoute route', () => {
);
});
- test('returns an empty object when "availableIndices" indices are not available', async () => {
+ test('returns an empty object when "availableIndices" indices are empty', async () => {
const request = requestMock.create({
method: 'get',
path: GET_INDEX_STATS,
@@ -214,9 +204,7 @@ describe('getIndexStatsRoute route', () => {
const mockIndices = {};
(fetchMeteringStats as jest.Mock).mockResolvedValue(mockMeteringStatsIndex);
- (fetchAvailableIndices as jest.Mock).mockResolvedValue({
- aggregations: undefined,
- });
+ (fetchAvailableIndices as jest.Mock).mockResolvedValue([]);
const response = await server.inject(request, requestContextMock.convertContext(context));
expect(response.status).toEqual(200);
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.ts
index 665c178c62cdf..d1bb25d34fc2a 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/get_index_stats.ts
@@ -26,7 +26,11 @@ export const getIndexStatsRoute = (router: IRouter, logger: Logger) => {
.get({
path: GET_INDEX_STATS,
access: 'internal',
- options: { tags: ['access:securitySolution'] },
+ security: {
+ authz: {
+ requiredPrivileges: ['securitySolution'],
+ },
+ },
})
.addVersion(
{
@@ -86,7 +90,7 @@ export const getIndexStatsRoute = (router: IRouter, logger: Logger) => {
endDate: decodedEndDate,
});
- if (!availableIndices.aggregations?.index?.buckets) {
+ if (availableIndices.length === 0) {
logger.warn(
`No available indices found under pattern: ${decodedIndexName}, in the given date range: ${decodedStartDate} - ${decodedEndDate}`
);
@@ -95,10 +99,7 @@ export const getIndexStatsRoute = (router: IRouter, logger: Logger) => {
});
}
- const indices = pickAvailableMeteringStats(
- availableIndices.aggregations.index.buckets,
- meteringStatsIndices
- );
+ const indices = pickAvailableMeteringStats(availableIndices, meteringStatsIndices);
return response.ok({
body: indices,
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results.ts
index bbab7dede3c21..71f2422146f9c 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results.ts
@@ -87,7 +87,11 @@ export const getIndexResultsRoute = (
.get({
path: GET_INDEX_RESULTS,
access: 'internal',
- options: { tags: ['access:securitySolution'] },
+ security: {
+ authz: {
+ requiredPrivileges: ['securitySolution'],
+ },
+ },
})
.addVersion(
{
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results_latest.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results_latest.ts
index 55ff8e01a01dc..3a294409af869 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results_latest.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/get_index_results_latest.ts
@@ -41,7 +41,11 @@ export const getIndexResultsLatestRoute = (
.get({
path: GET_INDEX_RESULTS_LATEST,
access: 'internal',
- options: { tags: ['access:securitySolution'] },
+ security: {
+ authz: {
+ requiredPrivileges: ['securitySolution'],
+ },
+ },
})
.addVersion(
{
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/post_index_results.ts b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/post_index_results.ts
index 5e87cadb4dadf..0c627d4cc0364 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/post_index_results.ts
+++ b/x-pack/plugins/ecs_data_quality_dashboard/server/routes/results/post_index_results.ts
@@ -24,7 +24,11 @@ export const postIndexResultsRoute = (
.post({
path: POST_INDEX_RESULTS,
access: 'internal',
- options: { tags: ['access:securitySolution'] },
+ security: {
+ authz: {
+ requiredPrivileges: ['securitySolution'],
+ },
+ },
})
.addVersion(
{
diff --git a/x-pack/plugins/ecs_data_quality_dashboard/tsconfig.json b/x-pack/plugins/ecs_data_quality_dashboard/tsconfig.json
index ceb43169165b4..cf31d7461b509 100644
--- a/x-pack/plugins/ecs_data_quality_dashboard/tsconfig.json
+++ b/x-pack/plugins/ecs_data_quality_dashboard/tsconfig.json
@@ -26,6 +26,7 @@
"@kbn/core-elasticsearch-server-mocks",
"@kbn/core-elasticsearch-server",
"@kbn/core-security-common",
+ "@kbn/datemath",
],
"exclude": [
"target/**/*",
diff --git a/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.test.ts b/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.test.ts
index 4aca370aa700f..f03a3394cdaac 100644
--- a/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.test.ts
+++ b/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.test.ts
@@ -290,6 +290,7 @@ describe('chatCompleteRoute', () => {
actionTypeId: '.gen-ai',
model: 'gpt-4',
assistantStreamingEnabled: false,
+ isEnabledKnowledgeBase: false,
});
}),
};
diff --git a/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.ts b/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.ts
index f2365f0320967..c6eb81dd86ebd 100644
--- a/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.ts
+++ b/x-pack/plugins/elastic_assistant/server/routes/chat/chat_complete_route.ts
@@ -25,6 +25,9 @@ import { buildResponse } from '../../lib/build_response';
import {
appendAssistantMessageToConversation,
createConversationWithUserInput,
+ DEFAULT_PLUGIN_NAME,
+ getIsKnowledgeBaseInstalled,
+ getPluginNameFromRequest,
langChainExecute,
performChecks,
} from '../helpers';
@@ -63,9 +66,9 @@ export const chatCompleteRoute = (
const assistantResponse = buildResponse(response);
let telemetry;
let actionTypeId;
+ const ctx = await context.resolve(['core', 'elasticAssistant', 'licensing']);
+ const logger: Logger = ctx.elasticAssistant.logger;
try {
- const ctx = await context.resolve(['core', 'elasticAssistant', 'licensing']);
- const logger: Logger = ctx.elasticAssistant.logger;
telemetry = ctx.elasticAssistant.telemetry;
const inference = ctx.elasticAssistant.inference;
@@ -219,6 +222,19 @@ export const chatCompleteRoute = (
});
} catch (err) {
const error = transformError(err as Error);
+ const pluginName = getPluginNameFromRequest({
+ request,
+ defaultPluginName: DEFAULT_PLUGIN_NAME,
+ logger,
+ });
+ const v2KnowledgeBaseEnabled =
+ ctx.elasticAssistant.getRegisteredFeatures(pluginName).assistantKnowledgeBaseByDefault;
+ const kbDataClient =
+ (await ctx.elasticAssistant.getAIAssistantKnowledgeBaseDataClient({
+ v2KnowledgeBaseEnabled,
+ })) ?? undefined;
+ const isKnowledgeBaseInstalled = await getIsKnowledgeBaseInstalled(kbDataClient);
+
telemetry?.reportEvent(INVOKE_ASSISTANT_ERROR_EVENT.eventType, {
actionTypeId: actionTypeId ?? '',
model: request.body.model,
@@ -226,6 +242,7 @@ export const chatCompleteRoute = (
// TODO rm actionTypeId check when llmClass for bedrock streaming is implemented
// tracked here: https://github.com/elastic/security-team/issues/7363
assistantStreamingEnabled: request.body.isStream ?? false,
+ isEnabledKnowledgeBase: isKnowledgeBaseInstalled,
});
return assistantResponse.error({
body: error.message,
diff --git a/x-pack/plugins/elastic_assistant/server/routes/helpers.ts b/x-pack/plugins/elastic_assistant/server/routes/helpers.ts
index bf12a99a0afbb..d25ed5fc77f10 100644
--- a/x-pack/plugins/elastic_assistant/server/routes/helpers.ts
+++ b/x-pack/plugins/elastic_assistant/server/routes/helpers.ts
@@ -35,7 +35,7 @@ import { FindResponse } from '../ai_assistant_data_clients/find';
import { EsPromptsSchema } from '../ai_assistant_data_clients/prompts/types';
import { AIAssistantDataClient } from '../ai_assistant_data_clients';
import { MINIMUM_AI_ASSISTANT_LICENSE } from '../../common/constants';
-import { ESQL_DOCS_LOADED_QUERY } from './knowledge_base/constants';
+import { SECURITY_LABS_RESOURCE, SECURITY_LABS_LOADED_QUERY } from './knowledge_base/constants';
import { buildResponse, getLlmType } from './utils';
import {
AgentExecutorParams,
@@ -436,15 +436,13 @@ export const langChainExecute = async ({
executorParams
);
- const { esqlExists, isModelDeployed } = await getIsKnowledgeBaseEnabled(kbDataClient);
+ const isKnowledgeBaseInstalled = await getIsKnowledgeBaseInstalled(kbDataClient);
telemetry.reportEvent(INVOKE_ASSISTANT_SUCCESS_EVENT.eventType, {
actionTypeId,
model: request.body.model,
- // TODO rm actionTypeId check when llmClass for bedrock streaming is implemented
- // tracked here: https://github.com/elastic/security-team/issues/7363
- assistantStreamingEnabled: isStream && actionTypeId === '.gen-ai',
- isEnabledKnowledgeBase: isModelDeployed && esqlExists,
+ assistantStreamingEnabled: isStream,
+ isEnabledKnowledgeBase: isKnowledgeBaseInstalled,
});
return response.ok(result);
};
@@ -671,23 +669,20 @@ export const isV2KnowledgeBaseEnabled = ({
* Telemetry function to determine whether knowledge base has been installed
* @param kbDataClient
*/
-export const getIsKnowledgeBaseEnabled = async (
+export const getIsKnowledgeBaseInstalled = async (
kbDataClient?: AIAssistantKnowledgeBaseDataClient | null
-): Promise<{
- esqlExists: boolean;
- isModelDeployed: boolean;
-}> => {
- let esqlExists = false;
+): Promise => {
+ let securityLabsDocsExist = false;
let isModelDeployed = false;
if (kbDataClient != null) {
try {
isModelDeployed = await kbDataClient.isModelDeployed();
if (isModelDeployed) {
- esqlExists =
+ securityLabsDocsExist =
(
await kbDataClient.getKnowledgeBaseDocumentEntries({
- query: ESQL_DOCS_LOADED_QUERY,
- required: true,
+ kbResource: SECURITY_LABS_RESOURCE,
+ query: SECURITY_LABS_LOADED_QUERY,
})
).length > 0;
}
@@ -696,8 +691,5 @@ export const getIsKnowledgeBaseEnabled = async (
}
}
- return {
- esqlExists,
- isModelDeployed,
- };
+ return isModelDeployed && securityLabsDocsExist;
};
diff --git a/x-pack/plugins/elastic_assistant/server/routes/knowledge_base/constants.ts b/x-pack/plugins/elastic_assistant/server/routes/knowledge_base/constants.ts
index 8bf17027e751e..052b2cac57609 100644
--- a/x-pack/plugins/elastic_assistant/server/routes/knowledge_base/constants.ts
+++ b/x-pack/plugins/elastic_assistant/server/routes/knowledge_base/constants.ts
@@ -13,3 +13,5 @@ export const ESQL_DOCS_LOADED_QUERY =
'You can chain processing commands, separated by a pipe character: `|`.';
export const SECURITY_LABS_RESOURCE = 'security_labs';
export const USER_RESOURCE = 'user';
+// Query for determining if Security Labs docs have been loaded. Intended for use with Telemetry
+export const SECURITY_LABS_LOADED_QUERY = 'What is Elastic Security Labs';
diff --git a/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.test.ts b/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.test.ts
index 998790f332c45..a7abac27dac6f 100644
--- a/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.test.ts
+++ b/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.test.ts
@@ -51,7 +51,7 @@ jest.mock('./helpers', () => {
return {
...original,
- getIsKnowledgeBaseEnabled: jest.fn(),
+ getIsKnowledgeBaseInstalled: jest.fn(),
appendAssistantMessageToConversation: jest.fn(),
langChainExecute: jest.fn(),
getPluginNameFromRequest: jest.fn(),
diff --git a/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.ts b/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.ts
index acf2dd32a060b..bb217f7f5aa3a 100644
--- a/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.ts
+++ b/x-pack/plugins/elastic_assistant/server/routes/post_actions_connector_execute.ts
@@ -24,7 +24,7 @@ import { ElasticAssistantRequestHandlerContext, GetElser } from '../types';
import {
appendAssistantMessageToConversation,
DEFAULT_PLUGIN_NAME,
- getIsKnowledgeBaseEnabled,
+ getIsKnowledgeBaseInstalled,
getPluginNameFromRequest,
getSystemPromptFromUserConversation,
langChainExecute,
@@ -170,14 +170,13 @@ export const postActionsConnectorExecuteRoute = (
(await assistantContext.getAIAssistantKnowledgeBaseDataClient({
v2KnowledgeBaseEnabled,
})) ?? undefined;
- const isEnabledKnowledgeBase = await getIsKnowledgeBaseEnabled(kbDataClient);
-
+ const isKnowledgeBaseInstalled = await getIsKnowledgeBaseInstalled(kbDataClient);
telemetry.reportEvent(INVOKE_ASSISTANT_ERROR_EVENT.eventType, {
actionTypeId: request.body.actionTypeId,
model: request.body.model,
errorMessage: error.message,
assistantStreamingEnabled: request.body.subAction !== 'invokeAI',
- isEnabledKnowledgeBase,
+ isEnabledKnowledgeBase: isKnowledgeBaseInstalled,
});
return resp.error({
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/api_logs/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/api_logs/components/empty_state.tsx
index c78bf3e918737..bf8cf009759d0 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/api_logs/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/api_logs/components/empty_state.tsx
@@ -11,7 +11,7 @@ import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { API_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyState: React.FC = () => (
(
}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.engine.apiLogs.empty.buttonLabel', {
defaultMessage: 'View the API reference',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/crawl_rules_table.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/crawl_rules_table.tsx
index bef8ed4462fdc..2f66dc455442e 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/crawl_rules_table.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/crawl_rules_table.tsx
@@ -23,11 +23,11 @@ import {
import { i18n } from '@kbn/i18n';
import { FormattedMessage } from '@kbn/i18n-react';
+import { docLinks } from '../../../../shared/doc_links';
import { clearFlashMessages, flashSuccessToast } from '../../../../shared/flash_messages';
import { GenericEndpointInlineEditableTable } from '../../../../shared/tables/generic_endpoint_inline_editable_table';
import { InlineEditableTableColumn } from '../../../../shared/tables/inline_editable_table/types';
import { ItemWithAnID } from '../../../../shared/tables/types';
-import { CRAWL_RULES_DOCS_URL } from '../../../routes';
import { CrawlerSingleDomainLogic } from '../crawler_single_domain_logic';
import {
CrawlerPolicies,
@@ -53,7 +53,7 @@ const DEFAULT_DESCRIPTION = (
defaultMessage="Create a crawl rule to include or exclude pages whose URL matches the rule. Rules run in sequential order, and each URL is evaluated according to the first match. {link}"
values={{
link: (
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.crawler.crawlRulesTable.descriptionLinkText',
{ defaultMessage: 'Learn more about crawl rules' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/deduplication_panel/deduplication_panel.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/deduplication_panel/deduplication_panel.tsx
index 26794d0421353..ef4d7448a5785 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/deduplication_panel/deduplication_panel.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/deduplication_panel/deduplication_panel.tsx
@@ -27,7 +27,7 @@ import { EuiSelectableLIOption } from '@elastic/eui/src/components/selectable/se
import { i18n } from '@kbn/i18n';
import { FormattedMessage } from '@kbn/i18n-react';
-import { DUPLICATE_DOCS_URL } from '../../../../routes';
+import { docLinks } from '../../../../../shared/doc_links';
import { DataPanel } from '../../../data_panel';
import { CrawlerSingleDomainLogic } from '../../crawler_single_domain_logic';
@@ -84,7 +84,7 @@ export const DeduplicationPanel: React.FC = () => {
documents on this domain. {documentationLink}."
values={{
documentationLink: (
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.crawler.deduplicationPanel.learnMoreMessage',
{
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/entry_points_table.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/entry_points_table.tsx
index 4fc7a0569ba0e..d4bfdf77704b8 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/entry_points_table.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/entry_points_table.tsx
@@ -14,10 +14,10 @@ import { EuiFieldText, EuiLink, EuiSpacer, EuiText, EuiTitle } from '@elastic/eu
import { i18n } from '@kbn/i18n';
import { FormattedMessage } from '@kbn/i18n-react';
+import { docLinks } from '../../../../shared/doc_links';
import { GenericEndpointInlineEditableTable } from '../../../../shared/tables/generic_endpoint_inline_editable_table';
import { InlineEditableTableColumn } from '../../../../shared/tables/inline_editable_table/types';
import { ItemWithAnID } from '../../../../shared/tables/types';
-import { ENTRY_POINTS_DOCS_URL } from '../../../routes';
import { CrawlerDomain, EntryPoint } from '../types';
import { EntryPointsTableLogic } from './entry_points_table_logic';
@@ -80,7 +80,7 @@ export const EntryPointsTable: React.FC = ({
defaultMessage:
'Include the most important URLs for your website here. Entry point URLs will be the first pages to be indexed and processed for links to other pages.',
})}{' '}
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.crawler.entryPointsTable.learnMoreLinkText',
{ defaultMessage: 'Learn more about entry points.' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/manage_crawls_popover/automatic_crawl_scheduler.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/manage_crawls_popover/automatic_crawl_scheduler.tsx
index 4533ca04c75bc..cb0377a471b93 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/manage_crawls_popover/automatic_crawl_scheduler.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/components/manage_crawls_popover/automatic_crawl_scheduler.tsx
@@ -36,8 +36,8 @@ import {
MONTHS_UNIT_LABEL,
WEEKS_UNIT_LABEL,
} from '../../../../../shared/constants/units';
+import { docLinks } from '../../../../../shared/doc_links';
-import { WEB_CRAWLER_DOCS_URL } from '../../../../routes';
import { CrawlUnits } from '../../types';
import { AutomaticCrawlSchedulerLogic } from './automatic_crawl_scheduler_logic';
@@ -81,7 +81,7 @@ export const AutomaticCrawlScheduler: React.FC = () => {
defaultMessage="Don't worry about it, we'll start a crawl for you. {readMoreMessage}."
values={{
readMoreMessage: (
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.crawler.automaticCrawlSchedule.readMoreLink',
{
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/crawler_overview.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/crawler_overview.tsx
index 13a13c25a5ad8..d18f40c4c9f23 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/crawler_overview.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/crawler/crawler_overview.tsx
@@ -13,7 +13,7 @@ import { EuiFlexGroup, EuiFlexItem, EuiLink, EuiSpacer, EuiText, EuiTitle } from
import { i18n } from '@kbn/i18n';
-import { WEB_CRAWLER_DOCS_URL, WEB_CRAWLER_LOG_DOCS_URL } from '../../routes';
+import { docLinks } from '../../../shared/doc_links';
import { getEngineBreadcrumbs } from '../engine';
import { AppSearchPageTemplate } from '../layout';
@@ -82,7 +82,7 @@ export const CrawlerOverview: React.FC = () => {
defaultMessage:
"Easily index your website's content. To get started, enter your domain name, provide optional entry points and crawl rules, and we will handle the rest.",
})}{' '}
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.crawler.empty.crawlerDocumentationLinkDescription',
{
@@ -125,7 +125,7 @@ export const CrawlerOverview: React.FC = () => {
defaultMessage:
"Recent crawl requests are logged here. Using the request ID of each crawl, you can track progress and examine crawl events in Kibana's Discover or Logs user interfaces.",
})}{' '}
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.crawler.configurationDocumentationLinkDescription',
{
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/constants.ts b/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/constants.ts
index 9676e7f859ac5..7468597294026 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/constants.ts
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/constants.ts
@@ -7,8 +7,6 @@
import { i18n } from '@kbn/i18n';
-import { AUTHENTICATION_DOCS_URL } from '../../routes';
-
export const CREDENTIALS_TITLE = i18n.translate(
'xpack.enterpriseSearch.appSearch.credentials.title',
{ defaultMessage: 'Credentials' }
@@ -108,5 +106,3 @@ export const TOKEN_TYPE_INFO = [
];
export const FLYOUT_ARIA_LABEL_ID = 'credentialsFlyoutTitle';
-
-export const DOCS_HREF = AUTHENTICATION_DOCS_URL;
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_flyout/form_components/key_type.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_flyout/form_components/key_type.tsx
index 2cf381d8f604f..5213f786dfead 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_flyout/form_components/key_type.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_flyout/form_components/key_type.tsx
@@ -12,8 +12,10 @@ import { useValues, useActions } from 'kea';
import { EuiFormRow, EuiSelect, EuiText, EuiLink } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
+import { docLinks } from '../../../../../shared/doc_links';
+
import { AppLogic } from '../../../../app_logic';
-import { TOKEN_TYPE_DESCRIPTION, TOKEN_TYPE_INFO, DOCS_HREF } from '../../constants';
+import { TOKEN_TYPE_DESCRIPTION, TOKEN_TYPE_INFO } from '../../constants';
import { CredentialsLogic } from '../../credentials_logic';
export const FormKeyType: React.FC = () => {
@@ -36,7 +38,7 @@ export const FormKeyType: React.FC = () => {
{tokenDescription}{' '}
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.credentials.documentationLink1', {
defaultMessage: 'Visit the documentation',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_list/credentials_list.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_list/credentials_list.tsx
index e351cdf36c657..4f45da9e26046 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_list/credentials_list.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/credentials/credentials_list/credentials_list.tsx
@@ -19,9 +19,9 @@ import {
import { i18n } from '@kbn/i18n';
import { EDIT_BUTTON_LABEL, DELETE_BUTTON_LABEL } from '../../../../shared/constants';
+import { docLinks } from '../../../../shared/doc_links';
import { HiddenText } from '../../../../shared/hidden_text';
import { convertMetaToPagination, handlePageChange } from '../../../../shared/table_pagination';
-import { API_KEYS_DOCS_URL } from '../../../routes';
import { TOKEN_TYPE_DISPLAY_NAMES } from '../constants';
import { CredentialsLogic } from '../credentials_logic';
import { ApiToken } from '../types';
@@ -141,7 +141,7 @@ export const CredentialsList: React.FC = () => {
defaultMessage: 'Allow applications to access Elastic App Search on your behalf.',
})}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.credentials.empty.buttonLabel', {
defaultMessage: 'Learn about API keys',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/curations/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/curations/components/empty_state.tsx
index 10d81f1623959..363da83d56aac 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/curations/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/curations/components/empty_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { CURATIONS_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyState: React.FC = () => (
(
}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.engine.curations.empty.buttonLabel', {
defaultMessage: 'Read the curations guide',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/creation_mode_components/api_code_example.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/creation_mode_components/api_code_example.tsx
index 7bbe276aedf69..98da6dc88ef57 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/creation_mode_components/api_code_example.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/creation_mode_components/api_code_example.tsx
@@ -30,8 +30,8 @@ import { FormattedMessage } from '@kbn/i18n-react';
import { DocumentCreationLogic } from '..';
import { CANCEL_BUTTON_LABEL } from '../../../../shared/constants';
+import { docLinks } from '../../../../shared/doc_links';
import { getEnterpriseSearchUrl } from '../../../../shared/enterprise_search_url';
-import { API_CLIENTS_DOCS_URL, INDEXING_DOCS_URL } from '../../../routes';
import { EngineLogic } from '../../engine';
import { EngineDetails } from '../../engine/types';
@@ -74,12 +74,12 @@ export const FlyoutBody: React.FC = () => {
defaultMessage="The {documentsApiLink} can be used to add new documents to your engine, update documents, retrieve documents by id, and delete documents. There are a variety of {clientLibrariesLink} to help you get started."
values={{
documentsApiLink: (
-
+
documents API
),
clientLibrariesLink: (
-
+
client libraries
),
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/document_creation_buttons.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/document_creation_buttons.tsx
index 07de7b3ec0c34..80e087e007671 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/document_creation_buttons.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/document_creation/document_creation_buttons.tsx
@@ -26,9 +26,10 @@ import {
} from '@elastic/eui';
import { i18n } from '@kbn/i18n';
+import { docLinks } from '../../../shared/doc_links';
import { parseQueryParams } from '../../../shared/query_params';
import { EuiCardTo } from '../../../shared/react_router_helpers';
-import { INDEXING_DOCS_URL, ENGINE_CRAWLER_PATH } from '../../routes';
+import { ENGINE_CRAWLER_PATH } from '../../routes';
import { generateEnginePath } from '../engine';
import illustration from './illustration.svg';
@@ -106,7 +107,7 @@ export const DocumentCreationButtons: React.FC = ({
)}
{' '}
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.documentCreation.buttons.emptyStateFooterLink',
{ defaultMessage: 'Read documentation' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/documents/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/documents/components/empty_state.tsx
index 85e834b320751..a311899d380e9 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/documents/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/documents/components/empty_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { INDEXING_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyState = () => (
(
}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.engine.documents.empty.buttonLabel', {
defaultMessage: 'Read the documents guide',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/engine_overview/engine_overview_empty.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/engine_overview/engine_overview_empty.tsx
index e31a17406ffd3..e4bcf810d58f8 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/engine_overview/engine_overview_empty.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/engine_overview/engine_overview_empty.tsx
@@ -12,8 +12,8 @@ import { useValues } from 'kea';
import { EuiButton, EuiEmptyPrompt, EuiImage, EuiSpacer } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
+import { docLinks } from '../../../shared/doc_links';
import { EuiButtonTo } from '../../../shared/react_router_helpers';
-import { DOCS_URL } from '../../routes';
import { DocumentCreationButtons, DocumentCreationFlyout } from '../document_creation';
import illustration from '../document_creation/illustration.svg';
@@ -85,7 +85,7 @@ export const EmptyEngineOverview: React.FC = () => {
{ defaultMessage: 'Engine setup' }
),
rightSideItems: [
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.engine.overview.empty.headingAction',
{ defaultMessage: 'View documentation' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/engines/components/empty_meta_engines_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/engines/components/empty_meta_engines_state.tsx
index 3cf461e3f7d45..0824997ba8896 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/engines/components/empty_meta_engines_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/engines/components/empty_meta_engines_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiEmptyPrompt, EuiButton } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { META_ENGINES_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyMetaEnginesState: React.FC = () => (
(
}
actions={
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.engines.metaEngines.emptyPromptButtonLabel',
{ defaultMessage: 'Learn more about meta engines' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/meta_engine_creation/constants.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/meta_engine_creation/constants.tsx
index e30868beeb209..8b32ffe77e701 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/meta_engine_creation/constants.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/meta_engine_creation/constants.tsx
@@ -11,7 +11,7 @@ import { EuiLink } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
import { FormattedMessage } from '@kbn/i18n-react';
-import { META_ENGINES_DOCS_URL } from '../../routes';
+import { docLinks } from '../../../shared/doc_links';
export const DEFAULT_LANGUAGE = 'Universal';
@@ -57,7 +57,7 @@ export const META_ENGINE_CREATION_FORM_DOCUMENTATION_DESCRIPTION = (
defaultMessage="{documentationLink} for information about how to get started."
values={{
documentationLink: (
-
+
{META_ENGINE_CREATION_FORM_DOCUMENTATION_LINK}
),
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/empty_state.tsx
index f17f7a582efdf..b792dec2cba0e 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/empty_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { RELEVANCE_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyState: React.FC = () => (
(
}
)}
actions={
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.engine.relevanceTuning.empty.buttonLabel',
{ defaultMessage: 'Read the relevance tuning guide' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/precision_slider/precision_slider.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/precision_slider/precision_slider.tsx
index e4b2027aa3d6d..d78949d0fbe74 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/precision_slider/precision_slider.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/components/precision_slider/precision_slider.tsx
@@ -21,7 +21,7 @@ import {
} from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { PRECISION_DOCS_URL } from '../../../../routes';
+import { docLinks } from '../../../../../shared/doc_links';
import { RelevanceTuningLogic } from '../../relevance_tuning_logic';
import { STEP_DESCRIPTIONS } from './constants';
@@ -57,7 +57,11 @@ export const PrecisionSlider: React.FC = () => {
defaultMessage: 'Fine tune the precision vs. recall settings on your engine.',
}
)}{' '}
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.engine.relevanceTuning.precisionSlider.learnMore.link',
{
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/relevance_tuning_callouts.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/relevance_tuning_callouts.tsx
index bf2c21a1003f5..ef0bea39439c5 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/relevance_tuning_callouts.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/relevance_tuning/relevance_tuning_callouts.tsx
@@ -13,8 +13,9 @@ import { EuiCallOut, EuiLink } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
import { FormattedMessage } from '@kbn/i18n-react';
+import { docLinks } from '../../../shared/doc_links';
import { EuiLinkTo } from '../../../shared/react_router_helpers';
-import { META_ENGINES_DOCS_URL, ENGINE_SCHEMA_PATH } from '../../routes';
+import { ENGINE_SCHEMA_PATH } from '../../routes';
import { EngineLogic, generateEnginePath } from '../engine';
import { RelevanceTuningLogic } from '.';
@@ -98,7 +99,7 @@ export const RelevanceTuningCallouts: React.FC = () => {
values={{
schemaFieldsWithConflictsCount,
link: (
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.engine.relevanceTuning.whatsThisLinkLabel',
{
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/result_settings/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/result_settings/components/empty_state.tsx
index 7f91447b910b6..6434a877ead5e 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/result_settings/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/result_settings/components/empty_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { RESULT_SETTINGS_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyState: React.FC = () => (
(
}
)}
actions={
-
+
{i18n.translate(
'xpack.enterpriseSearch.appSearch.engine.resultSettings.empty.buttonLabel',
{ defaultMessage: 'Read the result settings guide' }
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/role_mappings/role_mappings.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/role_mappings/role_mappings.tsx
index aff138b9c3884..2ffe6cb357e54 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/role_mappings/role_mappings.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/role_mappings/role_mappings.tsx
@@ -12,6 +12,7 @@ import { useActions, useValues } from 'kea';
import { EuiSpacer } from '@elastic/eui';
import { APP_SEARCH_PLUGIN } from '../../../../../common/constants';
+import { docLinks } from '../../../shared/doc_links';
import {
RoleMappingsTable,
RoleMappingsHeading,
@@ -22,7 +23,6 @@ import {
} from '../../../shared/role_mapping';
import { ROLE_MAPPINGS_TITLE } from '../../../shared/role_mapping/constants';
-import { SECURITY_DOCS_URL } from '../../routes';
import { AppSearchPageTemplate } from '../layout';
import { ROLE_MAPPINGS_ENGINE_ACCESS_HEADING } from './constants';
@@ -57,7 +57,7 @@ export const RoleMappings: React.FC = () => {
const rolesEmptyState = (
);
@@ -66,7 +66,7 @@ export const RoleMappings: React.FC = () => {
initializeRoleMapping()}
/>
{
@@ -40,7 +40,12 @@ export const EmptyState: React.FC = () => {
}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.engine.schema.empty.buttonLabel', {
defaultMessage: 'Read the indexing schema guide',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/components/empty_state.tsx
index 9a663e1372211..e5b0f2facedbd 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/components/empty_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { SEARCH_UI_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
export const EmptyState: React.FC = () => (
(
}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.engine.searchUI.empty.buttonLabel', {
defaultMessage: 'Read the Search UI guide',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/search_ui.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/search_ui.tsx
index d7398357a5e58..cfef71d34fb9f 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/search_ui.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/search_ui/search_ui.tsx
@@ -12,7 +12,7 @@ import { useActions, useValues } from 'kea';
import { EuiText, EuiFlexItem, EuiFlexGroup, EuiSpacer, EuiLink } from '@elastic/eui';
import { FormattedMessage } from '@kbn/i18n-react';
-import { SEARCH_UI_DOCS_URL } from '../../routes';
+import { docLinks } from '../../../shared/doc_links';
import { EngineLogic, getEngineBreadcrumbs } from '../engine';
import { AppSearchPageTemplate } from '../layout';
@@ -63,7 +63,7 @@ export const SearchUI: React.FC = () => {
defaultMessage="Use the fields below to generate a sample search experience built with Search UI. Use the sample to preview search results, or build upon it to create your own custom search experience. {link}."
values={{
link: (
-
+
{
defaultMessage: 'Log retention is determined by the ILM policies for your deployment.',
})}
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.settings.logRetention.learnMore', {
defaultMessage: 'Learn more about log retention for Enterprise Search.',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/components/synonyms/components/empty_state.tsx b/x-pack/plugins/enterprise_search/public/applications/app_search/components/synonyms/components/empty_state.tsx
index ef5e1dafa443f..ff7e8ce16c6d2 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/components/synonyms/components/empty_state.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/components/synonyms/components/empty_state.tsx
@@ -10,7 +10,7 @@ import React from 'react';
import { EuiEmptyPrompt, EuiButton } from '@elastic/eui';
import { i18n } from '@kbn/i18n';
-import { SYNONYMS_DOCS_URL } from '../../../routes';
+import { docLinks } from '../../../../shared/doc_links';
import { SynonymModal, SynonymIcon } from '.';
@@ -35,7 +35,7 @@ export const EmptyState: React.FC = () => {
}
actions={
-
+
{i18n.translate('xpack.enterpriseSearch.appSearch.engine.synonyms.empty.buttonLabel', {
defaultMessage: 'Read the synonyms guide',
})}
diff --git a/x-pack/plugins/enterprise_search/public/applications/app_search/routes.ts b/x-pack/plugins/enterprise_search/public/applications/app_search/routes.ts
index 1a41004c882e3..128af5adacfad 100644
--- a/x-pack/plugins/enterprise_search/public/applications/app_search/routes.ts
+++ b/x-pack/plugins/enterprise_search/public/applications/app_search/routes.ts
@@ -5,30 +5,6 @@
* 2.0.
*/
-import { docLinks } from '../shared/doc_links';
-
-export const API_DOCS_URL = docLinks.appSearchApis;
-export const API_CLIENTS_DOCS_URL = docLinks.appSearchApiClients;
-export const API_KEYS_DOCS_URL = docLinks.appSearchApiKeys;
-export const AUTHENTICATION_DOCS_URL = docLinks.appSearchAuthentication;
-export const CRAWL_RULES_DOCS_URL = docLinks.appSearchCrawlRules;
-export const CURATIONS_DOCS_URL = docLinks.appSearchCurations;
-export const DOCS_URL = docLinks.appSearchGuide;
-export const DUPLICATE_DOCS_URL = docLinks.appSearchDuplicateDocuments;
-export const ENTRY_POINTS_DOCS_URL = docLinks.appSearchEntryPoints;
-export const INDEXING_DOCS_URL = docLinks.appSearchIndexingDocs;
-export const INDEXING_SCHEMA_DOCS_URL = docLinks.appSearchIndexingDocsSchema;
-export const LOG_SETTINGS_DOCS_URL = docLinks.appSearchLogSettings;
-export const META_ENGINES_DOCS_URL = docLinks.appSearchMetaEngines;
-export const PRECISION_DOCS_URL = docLinks.appSearchPrecision;
-export const RELEVANCE_DOCS_URL = docLinks.appSearchRelevance;
-export const RESULT_SETTINGS_DOCS_URL = docLinks.appSearchResultSettings;
-export const SEARCH_UI_DOCS_URL = docLinks.appSearchSearchUI;
-export const SECURITY_DOCS_URL = docLinks.appSearchSecurity;
-export const SYNONYMS_DOCS_URL = docLinks.appSearchSynonyms;
-export const WEB_CRAWLER_DOCS_URL = docLinks.appSearchWebCrawler;
-export const WEB_CRAWLER_LOG_DOCS_URL = docLinks.appSearchWebCrawlerEventLogs;
-
export const ROOT_PATH = '/';
export const SETUP_GUIDE_PATH = '/setup_guide';
export const LIBRARY_PATH = '/library';
diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_content/components/connectors/create_connector/start_step.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_content/components/connectors/create_connector/start_step.tsx
index 9a93b43f6b751..7e23474b207f1 100644
--- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_content/components/connectors/create_connector/start_step.tsx
+++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_content/components/connectors/create_connector/start_step.tsx
@@ -27,6 +27,7 @@ import {
import { i18n } from '@kbn/i18n';
import * as Constants from '../../../../shared/constants';
+import { isValidIndexName } from '../../../utils/validate_index_name';
import { GeneratedConfigFields } from '../../connector_detail/components/generated_config_fields';
import { ConnectorViewLogic } from '../../connector_detail/connector_view_logic';
@@ -71,6 +72,18 @@ export const StartStep: React.FC = ({
setRawName(e.target.value);
};
+ const formError = isValidIndexName(rawName)
+ ? error
+ : i18n.translate(
+ 'xpack.enterpriseSearch.createConnector.startStep.euiFormRow.nameInputHelpText.lineOne',
+ {
+ defaultMessage: '{connectorName} is an invalid index name',
+ values: {
+ connectorName: rawName,
+ },
+ }
+ );
+
return (
@@ -100,6 +113,22 @@ export const StartStep: React.FC = ({
'xpack.enterpriseSearch.createConnector.startStep.euiFormRow.connectorNameLabel',
{ defaultMessage: 'Connector name' }
)}
+ helpText={
+ <>
+
+ {formError}
+
+
+ {i18n.translate(
+ 'xpack.enterpriseSearch.startStep.namesShouldBeLowercaseTextLabel',
+ {
+ defaultMessage:
+ 'The connector name should be lowercase and cannot contain spaces or special characters.',
+ }
+ )}
+
+ >
+ }
>
= ({
'xpack.enterpriseSearch.createConnector.startStep.euiFormRow.descriptionLabel',
{ defaultMessage: 'Description' }
)}
+ labelAppend={
+
+ {i18n.translate(
+ 'xpack.enterpriseSearch.createConnector.startStep.euiFormRow.descriptionLabelAppend',
+ { defaultMessage: 'Optional' }
+ )}
+
+ }
>
= ({
hasShadow={false}
hasBorder
paddingSize="l"
- color={selectedConnector?.name ? 'plain' : 'subdued'}
+ color={
+ selectedConnector?.name && isValidIndexName(rawName) && !error ? 'plain' : 'subdued'
+ }
>
-
+
{i18n.translate(
'xpack.enterpriseSearch.createConnector.startStep.h4.deploymentLabel',
@@ -218,7 +263,10 @@ export const StartStep: React.FC = ({
-
+
{i18n.translate(
'xpack.enterpriseSearch.createConnector.startStep.p.youWillStartTheLabel',
@@ -242,7 +290,7 @@ export const StartStep: React.FC = ({
}
}}
fill
- disabled={!canConfigureConnector}
+ disabled={!canConfigureConnector || !isValidIndexName(rawName) || Boolean(error)}
isLoading={isCreateLoading || isGenerateLoading}
>
{Constants.NEXT_BUTTON_LABEL}
@@ -252,12 +300,20 @@ export const StartStep: React.FC = ({
) : (
-
+
{i18n.translate(
'xpack.enterpriseSearch.createConnector.startStep.h4.configureIndexAndAPILabel',
@@ -268,7 +324,14 @@ export const StartStep: React.FC = ({
-
+
{i18n.translate(
'xpack.enterpriseSearch.createConnector.startStep.p.thisProcessWillCreateLabel',
@@ -309,7 +372,9 @@ export const StartStep: React.FC = ({
= ({
diff --git a/x-pack/plugins/file_upload/public/components/__snapshots__/import_complete_view.test.tsx.snap b/x-pack/plugins/file_upload/public/components/__snapshots__/import_complete_view.test.tsx.snap
index 8dd4858dfea5d..4108062e4fec4 100644
--- a/x-pack/plugins/file_upload/public/components/__snapshots__/import_complete_view.test.tsx.snap
+++ b/x-pack/plugins/file_upload/public/components/__snapshots__/import_complete_view.test.tsx.snap
@@ -348,7 +348,7 @@ exports[`Should render success 1`] = `
/>
{
) {
diff --git a/x-pack/plugins/fleet/kibana.jsonc b/x-pack/plugins/fleet/kibana.jsonc
index dec968457f294..823328da8ada6 100644
--- a/x-pack/plugins/fleet/kibana.jsonc
+++ b/x-pack/plugins/fleet/kibana.jsonc
@@ -29,7 +29,8 @@
"uiActions",
"dashboard",
"fieldsMetadata",
- "logsDataAccess"
+ "logsDataAccess",
+ "spaces"
],
"optionalPlugins": [
"features",
@@ -40,7 +41,6 @@
"telemetry",
"discover",
"ingestPipelines",
- "spaces",
"guidedOnboarding",
"integrationAssistant"
],
diff --git a/x-pack/plugins/fleet/public/applications/fleet/components/fleet_server_instructions/hooks/use_quick_start_form.ts b/x-pack/plugins/fleet/public/applications/fleet/components/fleet_server_instructions/hooks/use_quick_start_form.ts
index e56ae45b1661a..559fcad522351 100644
--- a/x-pack/plugins/fleet/public/applications/fleet/components/fleet_server_instructions/hooks/use_quick_start_form.ts
+++ b/x-pack/plugins/fleet/public/applications/fleet/components/fleet_server_instructions/hooks/use_quick_start_form.ts
@@ -5,30 +5,35 @@
* 2.0.
*/
-import { useState, useCallback, useEffect } from 'react';
+import { useState, useCallback, useEffect, useMemo } from 'react';
import { i18n } from '@kbn/i18n';
+import { getDefaultFleetServerpolicyId } from '../../../../../../common/services/agent_policies_helpers';
import type { useComboInput, useInput, useSwitchInput } from '../../../hooks';
-import { sendCreateAgentPolicy, sendGetOneAgentPolicy, useStartServices } from '../../../hooks';
-
+import {
+ sendCreateAgentPolicy,
+ sendGetOneAgentPolicy,
+ useFleetStatus,
+ useStartServices,
+} from '../../../hooks';
import type { NewAgentPolicy } from '../../../types';
-
import type { FleetServerHost } from '../../../types';
-
import { useServiceToken } from '../../../hooks/use_service_token';
import { useSelectFleetServerPolicy } from './use_select_fleet_server_policy';
import { useFleetServerHost } from './use_fleet_server_host';
-const QUICK_START_FLEET_SERVER_POLICY_FIELDS: NewAgentPolicy = {
- id: 'fleet-server-policy',
- name: 'Fleet Server Policy',
- description: 'Fleet Server policy generated by Kibana',
- namespace: 'default',
- has_fleet_server: true,
- monitoring_enabled: ['logs', 'metrics'],
- is_default_fleet_server: true,
-};
+function getQuickStartFleetServerPolicyFields(spaceId?: string): NewAgentPolicy {
+ return {
+ id: getDefaultFleetServerpolicyId(spaceId),
+ name: 'Fleet Server Policy',
+ description: 'Fleet Server policy generated by Kibana',
+ namespace: 'default',
+ has_fleet_server: true,
+ monitoring_enabled: ['logs', 'metrics'],
+ is_default_fleet_server: true,
+ };
+}
export type QuickStartCreateFormStatus = 'initial' | 'loading' | 'error' | 'success';
@@ -69,6 +74,7 @@ export const useQuickStartCreateForm = (): QuickStartCreateForm => {
setFleetServerHost,
inputs,
} = useFleetServerHost();
+ const { spaceId } = useFleetStatus();
// When a validation error is surfaced from the Fleet Server host form, we want to treat it
// the same way we do errors from the service token or policy creation steps
@@ -81,6 +87,11 @@ export const useQuickStartCreateForm = (): QuickStartCreateForm => {
const { fleetServerPolicyId, setFleetServerPolicyId } = useSelectFleetServerPolicy();
const { serviceToken, generateServiceToken } = useServiceToken();
+ const quickStartFleetServerPolicyFields = useMemo(
+ () => getQuickStartFleetServerPolicyFields(spaceId),
+ [spaceId]
+ );
+
const submit = useCallback(async () => {
try {
if (!fleetServerHost || fleetServerHost) {
@@ -98,16 +109,14 @@ export const useQuickStartCreateForm = (): QuickStartCreateForm => {
await generateServiceToken();
- const existingPolicy = await sendGetOneAgentPolicy(
- QUICK_START_FLEET_SERVER_POLICY_FIELDS.id!
- );
+ const existingPolicy = await sendGetOneAgentPolicy(quickStartFleetServerPolicyFields.id!);
// Don't attempt to create the policy if it's already been created in a previous quick start flow
if (existingPolicy.data?.item) {
setFleetServerPolicyId(existingPolicy.data?.item.id);
} else {
const createPolicyResponse = await sendCreateAgentPolicy(
- QUICK_START_FLEET_SERVER_POLICY_FIELDS,
+ quickStartFleetServerPolicyFields,
{
withSysMonitoring: true,
}
@@ -134,6 +143,7 @@ export const useQuickStartCreateForm = (): QuickStartCreateForm => {
generateServiceToken,
setFleetServerPolicyId,
notifications.toasts,
+ quickStartFleetServerPolicyFields,
]);
return {
diff --git a/x-pack/plugins/fleet/server/services/agent_policy_create.ts b/x-pack/plugins/fleet/server/services/agent_policy_create.ts
index f370867fc493b..3902548581595 100644
--- a/x-pack/plugins/fleet/server/services/agent_policy_create.ts
+++ b/x-pack/plugins/fleet/server/services/agent_policy_create.ts
@@ -11,6 +11,7 @@ import type {
SavedObjectsClientContract,
} from '@kbn/core/server';
+import { getDefaultFleetServerpolicyId } from '../../common/services/agent_policies_helpers';
import type { HTTPAuthorizationHeader } from '../../common/http_authorization_header';
import {
@@ -27,23 +28,25 @@ import { bulkInstallPackages } from './epm/packages';
import { ensureDefaultEnrollmentAPIKeyForAgentPolicy } from './api_keys';
import { agentlessAgentService } from './agents/agentless_agent';
-const FLEET_SERVER_POLICY_ID = 'fleet-server-policy';
-
async function getFleetServerAgentPolicyId(
soClient: SavedObjectsClientContract
): Promise {
let agentPolicyId;
- // creating first fleet server policy with id 'fleet-server-policy'
+ // creating first fleet server policy with id '(space-)?fleet-server-policy'
let agentPolicy;
try {
- agentPolicy = await agentPolicyService.get(soClient, FLEET_SERVER_POLICY_ID, false);
+ agentPolicy = await agentPolicyService.get(
+ soClient,
+ getDefaultFleetServerpolicyId(soClient.getCurrentNamespace()),
+ false
+ );
} catch (err) {
if (!err.isBoom || err.output.statusCode !== 404) {
throw err;
}
}
if (!agentPolicy) {
- agentPolicyId = FLEET_SERVER_POLICY_ID;
+ agentPolicyId = getDefaultFleetServerpolicyId(soClient.getCurrentNamespace());
}
return agentPolicyId;
}
@@ -118,7 +121,7 @@ export async function createAgentPolicyWithPackages({
packagesToInstall.push(FLEET_SERVER_PACKAGE);
agentPolicyId = agentPolicyId || (await getFleetServerAgentPolicyId(soClient));
- if (agentPolicyId === FLEET_SERVER_POLICY_ID) {
+ if (agentPolicyId === getDefaultFleetServerpolicyId(spaceId)) {
// setting first fleet server policy to default, so that fleet server can enroll without setting policy_id
newPolicy.is_default_fleet_server = true;
}
diff --git a/x-pack/plugins/index_management/public/application/lib/data_streams.test.tsx b/x-pack/plugins/index_management/public/application/lib/data_streams.test.tsx
index 5cb0c461f46ba..da5e7b6591e56 100644
--- a/x-pack/plugins/index_management/public/application/lib/data_streams.test.tsx
+++ b/x-pack/plugins/index_management/public/application/lib/data_streams.test.tsx
@@ -4,7 +4,7 @@
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/
-import { getLifecycleValue } from './data_streams';
+import { deserializeGlobalMaxRetention, getLifecycleValue } from './data_streams';
describe('Data stream helpers', () => {
describe('getLifecycleValue', () => {
@@ -45,4 +45,36 @@ describe('Data stream helpers', () => {
).toBe('5 days');
});
});
+
+ describe('deserializeGlobalMaxRetention', () => {
+ it('if globalMaxRetention is undefined', () => {
+ expect(deserializeGlobalMaxRetention(undefined)).toEqual({});
+ });
+
+ it('split globalMaxRetention size and units', () => {
+ expect(deserializeGlobalMaxRetention('1000h')).toEqual({
+ size: '1000',
+ unit: 'h',
+ unitText: 'hours',
+ });
+ });
+
+ it('support all of the units that are accepted by es', () => {
+ expect(deserializeGlobalMaxRetention('1000ms')).toEqual({
+ size: '1000',
+ unit: 'ms',
+ unitText: 'milliseconds',
+ });
+ expect(deserializeGlobalMaxRetention('1000micros')).toEqual({
+ size: '1000',
+ unit: 'micros',
+ unitText: 'microseconds',
+ });
+ expect(deserializeGlobalMaxRetention('1000nanos')).toEqual({
+ size: '1000',
+ unit: 'nanos',
+ unitText: 'nanoseconds',
+ });
+ });
+ });
});
diff --git a/x-pack/plugins/index_management/public/application/lib/data_streams.tsx b/x-pack/plugins/index_management/public/application/lib/data_streams.tsx
index 71c8bb0f61177..6747e84df751d 100644
--- a/x-pack/plugins/index_management/public/application/lib/data_streams.tsx
+++ b/x-pack/plugins/index_management/public/application/lib/data_streams.tsx
@@ -121,3 +121,19 @@ export const isDSLWithILMIndices = (dataStream?: DataStream | null) => {
return;
};
+
+export const deserializeGlobalMaxRetention = (globalMaxRetention?: string) => {
+ if (!globalMaxRetention) {
+ return {};
+ }
+
+ const { size, unit } = splitSizeAndUnits(globalMaxRetention);
+ const availableTimeUnits = [...timeUnits, ...extraTimeUnits];
+ const match = availableTimeUnits.find((timeUnit) => timeUnit.value === unit);
+
+ return {
+ size,
+ unit,
+ unitText: match?.text ?? unit,
+ };
+};
diff --git a/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/edit_data_retention_modal.tsx b/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/edit_data_retention_modal.tsx
index f5eee4671481a..2c60e04be31a6 100644
--- a/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/edit_data_retention_modal.tsx
+++ b/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/edit_data_retention_modal.tsx
@@ -43,7 +43,7 @@ import { getIndexListUri } from '../../../../services/routing';
import { documentationService } from '../../../../services/documentation';
import { splitSizeAndUnits, DataStream } from '../../../../../../common';
import { timeUnits } from '../../../../constants/time_units';
-import { isDSLWithILMIndices } from '../../../../lib/data_streams';
+import { deserializeGlobalMaxRetention, isDSLWithILMIndices } from '../../../../lib/data_streams';
import { useAppContext } from '../../../../app_context';
import { UnitField } from '../../../../components/shared';
import { updateDataRetention } from '../../../../services/api';
@@ -214,6 +214,7 @@ export const EditDataRetentionModal: React.FunctionComponent = ({
const { history } = useAppContext();
const dslWithIlmIndices = isDSLWithILMIndices(dataStream);
const { size, unit } = splitSizeAndUnits(lifecycle?.data_retention as string);
+ const globalMaxRetention = deserializeGlobalMaxRetention(lifecycle?.globalMaxRetention);
const {
services: { notificationService },
config: { enableTogglingDataRetention, enableProjectLevelRetentionChecks },
@@ -331,8 +332,11 @@ export const EditDataRetentionModal: React.FunctionComponent = ({
<>
>
diff --git a/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.test.ts b/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.test.ts
index 0768d0990cdc0..87cc1d36526fb 100644
--- a/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.test.ts
+++ b/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.test.ts
@@ -47,6 +47,26 @@ describe('isBiggerThanGlobalMaxRetention', () => {
});
});
+ it('should correctly compare retention in all of the units that are accepted by es', () => {
+ // 1000 milliseconds = 1 seconds
+ expect(isBiggerThanGlobalMaxRetention(1, 's', '1000ms')).toBeUndefined();
+ expect(isBiggerThanGlobalMaxRetention(2, 's', '1000ms')).toEqual({
+ message: 'Maximum data retention period on this project is 1000 milliseconds.',
+ });
+
+ // 1000000 microseconds = 1 seconds
+ expect(isBiggerThanGlobalMaxRetention(1, 's', '1000000micros')).toBeUndefined();
+ expect(isBiggerThanGlobalMaxRetention(2, 'm', '1000000micros')).toEqual({
+ message: 'Maximum data retention period on this project is 1000000 microseconds.',
+ });
+
+ // 1000000000 microseconds = 1 seconds
+ expect(isBiggerThanGlobalMaxRetention(2, 's', '1000000000nanos'));
+ expect(isBiggerThanGlobalMaxRetention(2, 'h', '1000000000nanos')).toEqual({
+ message: 'Maximum data retention period on this project is 1000000000 nanoseconds.',
+ });
+ });
+
it('should throw an error for unknown time units', () => {
expect(() => isBiggerThanGlobalMaxRetention(10, 'x', '30d')).toThrow('Unknown unit: x');
});
diff --git a/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.ts b/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.ts
index 831ac2f4c26b9..8486f01fb5b44 100644
--- a/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.ts
+++ b/x-pack/plugins/index_management/public/application/sections/home/data_stream_list/edit_data_retention_modal/validations.ts
@@ -7,34 +7,44 @@
import { i18n } from '@kbn/i18n';
import { splitSizeAndUnits } from '../../../../../../common';
+import { deserializeGlobalMaxRetention } from '../../../../lib/data_streams';
-const convertToMinutes = (value: string) => {
+const convertToSeconds = (value: string) => {
const { size, unit } = splitSizeAndUnits(value);
const sizeNum = parseInt(size, 10);
switch (unit) {
case 'd':
- // days to minutes
- return sizeNum * 24 * 60;
+ // days to seconds
+ return sizeNum * 24 * 60 * 60;
case 'h':
- // hours to minutes
- return sizeNum * 60;
+ // hours to seconds
+ return sizeNum * 60 * 60;
case 'm':
- // minutes to minutes
- return sizeNum;
+ // minutes to seconds
+ return sizeNum * 60;
case 's':
- // seconds to minutes (round up if any remainder)
- return Math.ceil(sizeNum / 60);
+ // seconds to seconds
+ return sizeNum;
+ case 'ms':
+ // milliseconds to seconds
+ return sizeNum / 1000;
+ case 'micros':
+ // microseconds to seconds
+ return sizeNum / 1000 / 1000;
+ case 'nanos':
+ // nanoseconds to seconds
+ return sizeNum / 1000 / 1000 / 1000;
default:
throw new Error(`Unknown unit: ${unit}`);
}
};
const isRetentionBiggerThan = (valueA: string, valueB: string) => {
- const minutesA = convertToMinutes(valueA);
- const minutesB = convertToMinutes(valueB);
+ const secondsA = convertToSeconds(valueA);
+ const secondsB = convertToSeconds(valueB);
- return minutesA > minutesB;
+ return secondsA > secondsB;
};
export const isBiggerThanGlobalMaxRetention = (
@@ -46,14 +56,19 @@ export const isBiggerThanGlobalMaxRetention = (
return undefined;
}
+ const { size, unitText } = deserializeGlobalMaxRetention(globalMaxRetention);
return isRetentionBiggerThan(`${retentionValue}${retentionTimeUnit}`, globalMaxRetention)
? {
message: i18n.translate(
'xpack.idxMgmt.dataStreamsDetailsPanel.editDataRetentionModal.dataRetentionFieldMaxError',
{
- defaultMessage: 'Maximum data retention period on this project is {maxRetention} days.',
+ defaultMessage:
+ 'Maximum data retention period on this project is {maxRetention} {unitText}.',
// Remove the unit from the globalMaxRetention value
- values: { maxRetention: globalMaxRetention.slice(0, -1) },
+ values: {
+ maxRetention: size,
+ unitText,
+ },
}
),
}
diff --git a/x-pack/plugins/ml/public/application/components/job_selector/use_job_selection.ts b/x-pack/plugins/ml/public/application/components/job_selector/use_job_selection.ts
index 7fcc1e71e1808..51d1882084d3e 100644
--- a/x-pack/plugins/ml/public/application/components/job_selector/use_job_selection.ts
+++ b/x-pack/plugins/ml/public/application/components/job_selector/use_job_selection.ts
@@ -25,6 +25,24 @@ function getInvalidJobIds(jobs: MlJobWithTimeRange[], ids: string[]) {
});
}
+// This is useful when redirecting from dashboards where groupIds are treated as jobIds
+const getJobIdsFromGroups = (jobIds: string[], jobs: MlJobWithTimeRange[]) => {
+ const result = new Set();
+
+ jobIds.forEach((id) => {
+ const jobsInGroup = jobs.filter((job) => job.groups?.includes(id));
+
+ if (jobsInGroup.length > 0) {
+ jobsInGroup.forEach((job) => result.add(job.job_id));
+ } else {
+ // If it's not a group ID, keep it (regardless of whether it's valid or not)
+ result.add(id);
+ }
+ });
+
+ return Array.from(result);
+};
+
export interface JobSelection {
jobIds: string[];
selectedGroups: string[];
@@ -37,9 +55,9 @@ export const useJobSelection = (jobs: MlJobWithTimeRange[]) => {
const getJobSelection = useJobSelectionFlyout();
const tmpIds = useMemo(() => {
- const ids = globalState?.ml?.jobIds || [];
+ const ids = getJobIdsFromGroups(globalState?.ml?.jobIds || [], jobs);
return (typeof ids === 'string' ? [ids] : ids).map((id: string) => String(id));
- }, [globalState?.ml?.jobIds]);
+ }, [globalState?.ml?.jobIds, jobs]);
const invalidIds = useMemo(() => {
return getInvalidJobIds(jobs, tmpIds);
diff --git a/x-pack/plugins/ml/public/application/model_management/models_list.tsx b/x-pack/plugins/ml/public/application/model_management/models_list.tsx
index 9dbdf6069aff6..a717995d4ee14 100644
--- a/x-pack/plugins/ml/public/application/model_management/models_list.tsx
+++ b/x-pack/plugins/ml/public/application/model_management/models_list.tsx
@@ -957,6 +957,14 @@ export const ModelsList: FC = ({
}
});
+ setItemIdToExpandedRowMap((prev) => {
+ const newMap = { ...prev };
+ modelsToDelete.forEach((model) => {
+ delete newMap[model.model_id];
+ });
+ return newMap;
+ });
+
setModelsToDelete([]);
if (refreshList) {
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm.yaml
deleted file mode 100644
index d37137302fd21..0000000000000
--- a/x-pack/plugins/observability_solution/apm/docs/openapi/apm.yaml
+++ /dev/null
@@ -1,186 +0,0 @@
-openapi: 3.0.0
-info:
- title: APM UI
- version: 1.0.0
-tags:
- - name: APM agent keys
- description: >
- Configure APM agent keys to authorize requests from APM agents to the APM Server.
- - name: APM annotations
- description: >
- Annotate visualizations in the APM app with significant events.
- Annotations enable you to easily see how events are impacting the performance of your applications.
-paths:
- /api/apm/agent_keys:
- post:
- summary: Create an APM agent key
- description: Create a new agent key for APM.
- operationId: createAgentKey
- tags:
- - APM agent keys
- requestBody:
- required: true
- content:
- application/json:
- schema:
- type: object
- properties:
- name:
- type: string
- privileges:
- type: array
- items:
- type: string
- enum:
- - event:write
- - config_agent:read
- responses:
- "200":
- description: Agent key created successfully
- content:
- application/json:
- schema:
- type: object
- properties:
- api_key:
- type: string
- expiration:
- type: integer
- format: int64
- id:
- type: string
- name:
- type: string
- encoded:
- type: string
- /api/apm/services/{serviceName}/annotation/search:
- get:
- summary: Search for annotations
- description: Search for annotations related to a specific service.
- operationId: getAnnotation
- tags:
- - APM annotations
- parameters:
- - name: serviceName
- in: path
- required: true
- description: The name of the service
- schema:
- type: string
- - name: environment
- in: query
- required: false
- description: The environment to filter annotations by
- schema:
- type: string
- - name: start
- in: query
- required: false
- description: The start date for the search
- schema:
- type: string
- - name: end
- in: query
- required: false
- description: The end date for the search
- schema:
- type: string
- responses:
- "200":
- description: Successful response
- content:
- application/json:
- schema:
- type: object
- properties:
- annotations:
- type: array
- items:
- type: object
- properties:
- type:
- type: string
- enum:
- - version
- id:
- type: string
- "@timestamp":
- type: number
- text:
- type: string
- /api/apm/services/{serviceName}/annotation:
- post:
- summary: Create a service annotation
- description: Create a new annotation for a specific service.
- operationId: createAnnotation
- tags:
- - APM annotations
- parameters:
- - name: serviceName
- in: path
- required: true
- description: The name of the service
- schema:
- type: string
- requestBody:
- required: true
- content:
- application/json:
- schema:
- type: object
- properties:
- '@timestamp':
- type: string
- service:
- type: object
- properties:
- version:
- type: string
- environment:
- type: string
- message:
- type: string
- tags:
- type: array
- items:
- type: string
-
- responses:
- '200':
- description: Annotation created successfully
- content:
- application/json:
- schema:
- type: object
- properties:
- _id:
- type: string
- _index:
- type: string
- _source:
- type: object
- properties:
- annotation:
- type: string
- tags:
- type: array
- items:
- type: string
- message:
- type: string
- service:
- type: object
- properties:
- name:
- type: string
- environment:
- type: string
- version:
- type: string
- event:
- type: object
- properties:
- created:
- type: string
- '@timestamp':
- type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/README.md b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/README.md
index da35d6b891239..74b9c6a034821 100644
--- a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/README.md
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/README.md
@@ -2,16 +2,26 @@
This directory contains [OpenAPI specifications](https://swagger.io/specification/) for the [APM app API](https://www.elastic.co/guide/en/kibana/current/apm-api.html) in Kibana.
-Included:
+# OpenAPI (Experimental)
-* [Agent Configuration API](https://www.elastic.co/guide/en/kibana/current/agent-config-api.html)
-* [Annotation API](https://www.elastic.co/guide/en/kibana/current/apm-annotation-api.html)
+The current self-contained spec file is available as `bundled.json` or `bundled.yaml` and can be used for online tools like those found at .
+This spec is experimental and may be incomplete or change later.
-Not included:
+A guide about the openApi specification can be found at [https://swagger.io/docs/specification/about/](https://swagger.io/docs/specification/about/).
-* [APM agent Key API](https://www.elastic.co/guide/en/kibana/current/agent-key-api.html)
-* [RUM source map API](https://www.elastic.co/guide/en/kibana/current/rum-sourcemap-api.html)
+## The `openapi` folder
-The specifications for the included APIs are in the apm.yaml file in this directory.
+* `entrypoint.yaml` is the overview file which pulls together all the paths and components.
+* [Paths](paths/README.md): Defines each endpoint. A path can have one operation per http method.
+* [Components](components/README.md): Defines reusable components.
-These specifications are manually written. The missing ones will be included in the future.
+## Tools
+
+Generate the `bundled` files by running the following commands:
+
+```bash
+npx @redocly/cli bundle entrypoint.yaml --output bundled.yaml --ext yaml
+npx @redocly/cli bundle entrypoint.yaml --output bundled.json --ext json
+```
+
+Then join these files with the rest of the Kibana APIs per `oas_docs/README.md`
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.json b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.json
new file mode 100644
index 0000000000000..9fdcc3cdb6294
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.json
@@ -0,0 +1,1827 @@
+{
+ "openapi": "3.0.2",
+ "info": {
+ "title": "APM UI",
+ "version": "1.0.0"
+ },
+ "tags": [
+ {
+ "name": "APM agent keys",
+ "description": "Configure APM agent keys to authorize requests from APM agents to the APM Server.\n"
+ },
+ {
+ "name": "APM agent configuration",
+ "description": "Adjust APM agent configuration without need to redeploy your application.\n"
+ },
+ {
+ "name": "APM sourcemaps",
+ "description": "Configure APM source maps."
+ },
+ {
+ "name": "APM annotations",
+ "description": "Annotate visualizations in the APM app with significant events. Annotations enable you to easily see how events are impacting the performance of your applications.\n"
+ },
+ {
+ "name": "APM server schema",
+ "description": "Create APM fleet server schema."
+ }
+ ],
+ "paths": {
+ "/api/apm/agent_keys": {
+ "post": {
+ "summary": "Create an APM agent key",
+ "description": "Create a new agent key for APM.",
+ "operationId": "createAgentKey",
+ "tags": [
+ "APM agent keys"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/agent_keys_object"
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Agent key created successfully",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/agent_keys_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "500": {
+ "description": "Internal Server Error response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/500_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/services/{serviceName}/annotation/search": {
+ "get": {
+ "summary": "Search for annotations",
+ "description": "Search for annotations related to a specific service.",
+ "operationId": "getAnnotation",
+ "tags": [
+ "APM annotations"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "name": "serviceName",
+ "in": "path",
+ "required": true,
+ "description": "The name of the service",
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "name": "environment",
+ "in": "query",
+ "required": false,
+ "description": "The environment to filter annotations by",
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "name": "start",
+ "in": "query",
+ "required": false,
+ "description": "The start date for the search",
+ "schema": {
+ "type": "string"
+ }
+ },
+ {
+ "name": "end",
+ "in": "query",
+ "required": false,
+ "description": "The end date for the search",
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/annotation_search_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "500": {
+ "description": "Internal Server Error response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/500_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/services/{serviceName}/annotation": {
+ "post": {
+ "summary": "Create a service annotation",
+ "description": "Create a new annotation for a specific service.",
+ "operationId": "createAnnotation",
+ "tags": [
+ "APM annotations"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ },
+ {
+ "name": "serviceName",
+ "in": "path",
+ "required": true,
+ "description": "The name of the service",
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/create_annotation_object"
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Annotation created successfully",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/create_annotation_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/settings/agent-configuration": {
+ "get": {
+ "summary": "Get a list of agent configurations",
+ "operationId": "getAgentConfigurations",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/agent_configurations_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ },
+ "delete": {
+ "summary": "Delete agent configuration",
+ "operationId": "deleteAgentConfiguration",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/service_object"
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/delete_agent_configurations_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ },
+ "put": {
+ "summary": "Create or update agent configuration",
+ "operationId": "createUpdateAgentConfiguration",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ },
+ {
+ "name": "overwrite",
+ "in": "query",
+ "description": "If the config exists ?overwrite=true is required",
+ "schema": {
+ "type": "boolean"
+ }
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/agent_configuration_intake_object"
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "type": "object",
+ "additionalProperties": false
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/settings/agent-configuration/view": {
+ "get": {
+ "summary": "Get single agent configuration",
+ "operationId": "getSingleAgentConfiguration",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "name": "name",
+ "in": "query",
+ "description": "Service name",
+ "schema": {
+ "type": "string"
+ },
+ "example": "node"
+ },
+ {
+ "name": "environment",
+ "in": "query",
+ "description": "Service environment",
+ "schema": {
+ "type": "string"
+ },
+ "example": "prod"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/single_agent_configuration_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/settings/agent-configuration/search": {
+ "post": {
+ "summary": "Lookup single agent configuration",
+ "description": "This endpoint allows to search for single agent configuration and update 'applied_by_agent' field.\n",
+ "operationId": "searchSingleConfiguration",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/search_agent_configuration_object"
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/search_agent_configuration_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/settings/agent-configuration/environments": {
+ "get": {
+ "summary": "Get environments for service",
+ "operationId": "getEnvironmentsForService",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "name": "serviceName",
+ "in": "query",
+ "description": "The name of the service",
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/service_environments_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/settings/agent-configuration/agent_name": {
+ "get": {
+ "summary": "Get agent name for service",
+ "description": "Retrieve `agentName` for a service.",
+ "operationId": "getAgentNameForService",
+ "tags": [
+ "APM agent configuration"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "name": "serviceName",
+ "in": "query",
+ "description": "The name of the service",
+ "required": true,
+ "schema": {
+ "type": "string"
+ },
+ "example": "node"
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/service_agent_name_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/sourcemaps": {
+ "get": {
+ "summary": "Get source maps",
+ "description": "Returns an array of Fleet artifacts, including source map uploads.",
+ "operationId": "getSourceMaps",
+ "tags": [
+ "APM sourcemaps"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "name": "page",
+ "in": "query",
+ "description": "Page number",
+ "schema": {
+ "type": "number"
+ }
+ },
+ {
+ "name": "perPage",
+ "in": "query",
+ "description": "Number of records per page",
+ "schema": {
+ "type": "number"
+ }
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/source_maps_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "500": {
+ "description": "Internal Server Error response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/500_response"
+ }
+ }
+ }
+ },
+ "501": {
+ "description": "Not Implemented response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/501_response"
+ }
+ }
+ }
+ }
+ }
+ },
+ "post": {
+ "summary": "Upload source map",
+ "description": "Upload a source map for a specific service and version.",
+ "operationId": "uploadSourceMap",
+ "tags": [
+ "APM sourcemaps"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "multipart/form-data": {
+ "schema": {
+ "$ref": "#/components/schemas/upload_source_map_object"
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/upload_source_maps_response"
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "500": {
+ "description": "Internal Server Error response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/500_response"
+ }
+ }
+ }
+ },
+ "501": {
+ "description": "Not Implemented response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/501_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/sourcemaps/{id}": {
+ "delete": {
+ "summary": "Delete source map",
+ "description": "Delete a previously uploaded source map.",
+ "operationId": "deleteSourceMap",
+ "tags": [
+ "APM sourcemaps"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ },
+ {
+ "name": "id",
+ "in": "path",
+ "description": "Source map identifier",
+ "required": true,
+ "schema": {
+ "type": "string"
+ }
+ }
+ ],
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "type": "object",
+ "additionalProperties": false
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "500": {
+ "description": "Internal Server Error response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/500_response"
+ }
+ }
+ }
+ },
+ "501": {
+ "description": "Not Implemented response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/501_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "/api/apm/fleet/apm_server_schema": {
+ "post": {
+ "summary": "Save APM server schema",
+ "operationId": "saveApmServerSchema",
+ "tags": [
+ "APM server schema"
+ ],
+ "parameters": [
+ {
+ "$ref": "#/components/parameters/elastic_api_version"
+ },
+ {
+ "$ref": "#/components/parameters/kbn_xsrf"
+ }
+ ],
+ "requestBody": {
+ "required": true,
+ "content": {
+ "application/json": {
+ "schema": {
+ "type": "object",
+ "properties": {
+ "schema": {
+ "type": "object",
+ "description": "Schema object",
+ "additionalProperties": true,
+ "example": {
+ "foo": "bar"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "responses": {
+ "200": {
+ "description": "Successful response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "type": "object",
+ "additionalProperties": false
+ }
+ }
+ }
+ },
+ "400": {
+ "description": "Bad Request response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/400_response"
+ }
+ }
+ }
+ },
+ "401": {
+ "description": "Unauthorized response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/401_response"
+ }
+ }
+ }
+ },
+ "403": {
+ "description": "Forbidden response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/403_response"
+ }
+ }
+ }
+ },
+ "404": {
+ "description": "Not found response",
+ "content": {
+ "application/json": {
+ "schema": {
+ "$ref": "#/components/schemas/404_response"
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ "components": {
+ "parameters": {
+ "elastic_api_version": {
+ "description": "The version of the API to use",
+ "in": "header",
+ "name": "elastic-api-version",
+ "required": true,
+ "schema": {
+ "default": "2023-10-31",
+ "enum": [
+ "2023-10-31"
+ ],
+ "type": "string"
+ }
+ },
+ "kbn_xsrf": {
+ "description": "A required header to protect against CSRF attacks",
+ "in": "header",
+ "name": "kbn-xsrf",
+ "required": true,
+ "schema": {
+ "example": "true",
+ "type": "string"
+ }
+ }
+ },
+ "schemas": {
+ "agent_keys_object": {
+ "type": "object",
+ "required": [
+ "name",
+ "privileges"
+ ],
+ "properties": {
+ "name": {
+ "type": "string",
+ "description": "Agent name"
+ },
+ "privileges": {
+ "type": "array",
+ "description": "Privileges configuration",
+ "items": {
+ "type": "string",
+ "enum": [
+ "event:write",
+ "config_agent:read"
+ ]
+ }
+ }
+ }
+ },
+ "agent_keys_response": {
+ "type": "object",
+ "properties": {
+ "agentKey": {
+ "type": "object",
+ "description": "Agent key",
+ "required": [
+ "id",
+ "name",
+ "api_key",
+ "encoded"
+ ],
+ "properties": {
+ "expiration": {
+ "type": "integer",
+ "format": "int64"
+ },
+ "id": {
+ "type": "string"
+ },
+ "name": {
+ "type": "string"
+ },
+ "api_key": {
+ "type": "string"
+ },
+ "encoded": {
+ "type": "string"
+ }
+ }
+ }
+ }
+ },
+ "400_response": {
+ "type": "object",
+ "properties": {
+ "statusCode": {
+ "type": "number",
+ "example": 400,
+ "description": "Error status code"
+ },
+ "error": {
+ "type": "string",
+ "example": "Not Found",
+ "description": "Error type"
+ },
+ "message": {
+ "type": "string",
+ "example": "Not Found",
+ "description": "Error message"
+ }
+ }
+ },
+ "401_response": {
+ "type": "object",
+ "properties": {
+ "statusCode": {
+ "type": "number",
+ "example": 401,
+ "description": "Error status code"
+ },
+ "error": {
+ "type": "string",
+ "example": "Unauthorized",
+ "description": "Error type"
+ },
+ "message": {
+ "type": "string",
+ "description": "Error message"
+ }
+ }
+ },
+ "403_response": {
+ "type": "object",
+ "properties": {
+ "statusCode": {
+ "type": "number",
+ "example": 403,
+ "description": "Error status code"
+ },
+ "error": {
+ "type": "string",
+ "example": "Forbidden",
+ "description": "Error type"
+ },
+ "message": {
+ "type": "string",
+ "description": "Error message"
+ }
+ }
+ },
+ "500_response": {
+ "type": "object",
+ "properties": {
+ "statusCode": {
+ "type": "number",
+ "example": 500,
+ "description": "Error status code"
+ },
+ "error": {
+ "type": "string",
+ "example": "Internal Server Error",
+ "description": "Error type"
+ },
+ "message": {
+ "type": "string",
+ "description": "Error message"
+ }
+ }
+ },
+ "annotation_search_response": {
+ "type": "object",
+ "properties": {
+ "annotations": {
+ "type": "array",
+ "description": "Annotations",
+ "items": {
+ "type": "object",
+ "properties": {
+ "type": {
+ "type": "string",
+ "enum": [
+ "version"
+ ]
+ },
+ "id": {
+ "type": "string"
+ },
+ "@timestamp": {
+ "type": "number"
+ },
+ "text": {
+ "type": "string"
+ }
+ }
+ }
+ }
+ }
+ },
+ "create_annotation_object": {
+ "type": "object",
+ "required": [
+ "@timestamp",
+ "service"
+ ],
+ "properties": {
+ "@timestamp": {
+ "type": "string",
+ "description": "Timestamp"
+ },
+ "service": {
+ "type": "object",
+ "description": "Service",
+ "required": [
+ "version"
+ ],
+ "properties": {
+ "version": {
+ "type": "string"
+ },
+ "environment": {
+ "type": "string"
+ }
+ }
+ },
+ "message": {
+ "type": "string",
+ "description": "Message"
+ },
+ "tags": {
+ "type": "array",
+ "description": "Tags",
+ "items": {
+ "type": "string"
+ }
+ }
+ }
+ },
+ "create_annotation_response": {
+ "type": "object",
+ "properties": {
+ "_id": {
+ "type": "string",
+ "description": "Identifier"
+ },
+ "_index": {
+ "type": "string",
+ "description": "Index"
+ },
+ "_source": {
+ "type": "object",
+ "description": "Response",
+ "properties": {
+ "annotation": {
+ "type": "object",
+ "properties": {
+ "type": {
+ "type": "string"
+ },
+ "title": {
+ "type": "string"
+ }
+ }
+ },
+ "tags": {
+ "type": "array",
+ "items": {
+ "type": "string"
+ }
+ },
+ "message": {
+ "type": "string"
+ },
+ "service": {
+ "type": "object",
+ "properties": {
+ "name": {
+ "type": "string"
+ },
+ "environment": {
+ "type": "string"
+ },
+ "version": {
+ "type": "string"
+ }
+ }
+ },
+ "event": {
+ "type": "object",
+ "properties": {
+ "created": {
+ "type": "string"
+ }
+ }
+ },
+ "@timestamp": {
+ "type": "string"
+ }
+ }
+ }
+ }
+ },
+ "404_response": {
+ "type": "object",
+ "properties": {
+ "statusCode": {
+ "type": "number",
+ "example": 404,
+ "description": "Error status code"
+ },
+ "error": {
+ "type": "string",
+ "example": "Not Found",
+ "description": "Error type"
+ },
+ "message": {
+ "type": "string",
+ "example": "Not Found",
+ "description": "Error message"
+ }
+ }
+ },
+ "service_object": {
+ "type": "object",
+ "description": "Service",
+ "properties": {
+ "name": {
+ "type": "string",
+ "example": "node",
+ "description": "Name"
+ },
+ "environment": {
+ "type": "string",
+ "example": "prod",
+ "description": "Environment"
+ }
+ }
+ },
+ "settings_object": {
+ "type": "object",
+ "description": "Agent configuration settings",
+ "additionalProperties": {
+ "type": "string"
+ }
+ },
+ "agent_configuration_object": {
+ "type": "object",
+ "required": [
+ "service",
+ "settings",
+ "@timestamp",
+ "etag"
+ ],
+ "description": "Agent configuration",
+ "properties": {
+ "agent_name": {
+ "type": "string",
+ "description": "Agent name"
+ },
+ "service": {
+ "$ref": "#/components/schemas/service_object"
+ },
+ "settings": {
+ "$ref": "#/components/schemas/settings_object"
+ },
+ "@timestamp": {
+ "type": "number",
+ "example": 1730194190636,
+ "description": "Timestamp"
+ },
+ "applied_by_agent": {
+ "type": "boolean",
+ "example": true,
+ "description": "Applied by agent"
+ },
+ "etag": {
+ "type": "string",
+ "example": "0bc3b5ebf18fba8163fe4c96f491e3767a358f85",
+ "description": "Etag"
+ }
+ }
+ },
+ "agent_configurations_response": {
+ "type": "object",
+ "properties": {
+ "configurations": {
+ "type": "array",
+ "description": "Agent configuration",
+ "items": {
+ "$ref": "#/components/schemas/agent_configuration_object"
+ }
+ }
+ }
+ },
+ "agent_configuration_intake_object": {
+ "type": "object",
+ "required": [
+ "service",
+ "settings"
+ ],
+ "properties": {
+ "agent_name": {
+ "type": "string",
+ "description": "Agent name"
+ },
+ "service": {
+ "$ref": "#/components/schemas/service_object"
+ },
+ "settings": {
+ "$ref": "#/components/schemas/settings_object"
+ }
+ }
+ },
+ "delete_agent_configurations_response": {
+ "type": "object",
+ "properties": {
+ "result": {
+ "type": "string",
+ "description": "Result"
+ }
+ }
+ },
+ "single_agent_configuration_response": {
+ "allOf": [
+ {
+ "type": "object",
+ "required": [
+ "id"
+ ],
+ "properties": {
+ "id": {
+ "type": "string"
+ }
+ }
+ },
+ {
+ "$ref": "#/components/schemas/agent_configuration_object"
+ }
+ ]
+ },
+ "search_agent_configuration_object": {
+ "type": "object",
+ "required": [
+ "service"
+ ],
+ "properties": {
+ "service": {
+ "$ref": "#/components/schemas/service_object"
+ },
+ "etag": {
+ "type": "string",
+ "description": "If etags match then `applied_by_agent` field will be set to `true`",
+ "example": "0bc3b5ebf18fba8163fe4c96f491e3767a358f85"
+ },
+ "mark_as_applied_by_agent": {
+ "type": "boolean",
+ "description": "`markAsAppliedByAgent=true` means \"force setting it to true regardless of etag\".\nThis is needed for Jaeger agent that doesn't have etags\n"
+ }
+ }
+ },
+ "search_agent_configuration_response": {
+ "type": "object",
+ "properties": {
+ "_index": {
+ "type": "string",
+ "description": "Index"
+ },
+ "_id": {
+ "type": "string",
+ "description": "Identifier"
+ },
+ "_score": {
+ "type": "number",
+ "description": "Score"
+ },
+ "_source": {
+ "$ref": "#/components/schemas/agent_configuration_object"
+ }
+ }
+ },
+ "service_environment_object": {
+ "type": "object",
+ "properties": {
+ "name": {
+ "type": "string",
+ "example": "ALL_OPTION_VALUE",
+ "description": "Service environment name"
+ },
+ "alreadyConfigured": {
+ "type": "boolean",
+ "description": "Already configured"
+ }
+ }
+ },
+ "service_environments_response": {
+ "type": "object",
+ "properties": {
+ "environments": {
+ "type": "array",
+ "description": "Service environment list",
+ "items": {
+ "$ref": "#/components/schemas/service_environment_object"
+ }
+ }
+ }
+ },
+ "service_agent_name_response": {
+ "type": "object",
+ "properties": {
+ "agentName": {
+ "type": "string",
+ "description": "Agent name",
+ "example": "nodejs"
+ }
+ }
+ },
+ "base_source_map_object": {
+ "type": "object",
+ "properties": {
+ "type": {
+ "type": "string",
+ "description": "Type"
+ },
+ "identifier": {
+ "type": "string",
+ "description": "Identifier"
+ },
+ "relative_url": {
+ "type": "string",
+ "description": "Relative URL"
+ },
+ "created": {
+ "type": "string",
+ "description": "Created date"
+ },
+ "id": {
+ "type": "string",
+ "description": "Identifier"
+ },
+ "compressionAlgorithm": {
+ "type": "string",
+ "description": "Compression Algorithm"
+ },
+ "decodedSha256": {
+ "type": "string",
+ "description": "Decoded SHA-256"
+ },
+ "decodedSize": {
+ "type": "number",
+ "description": "Decoded size"
+ },
+ "encodedSha256": {
+ "type": "string",
+ "description": "Encoded SHA-256"
+ },
+ "encodedSize": {
+ "type": "number",
+ "description": "Encoded size"
+ },
+ "encryptionAlgorithm": {
+ "type": "string",
+ "description": "Encryption Algorithm"
+ },
+ "packageName": {
+ "type": "string",
+ "description": "Package name"
+ }
+ }
+ },
+ "source_maps_response": {
+ "type": "object",
+ "properties": {
+ "artifacts": {
+ "type": "array",
+ "description": "Artifacts",
+ "items": {
+ "allOf": [
+ {
+ "type": "object",
+ "properties": {
+ "body": {
+ "type": "object",
+ "properties": {
+ "serviceName": {
+ "type": "string"
+ },
+ "serviceVersion": {
+ "type": "string"
+ },
+ "bundleFilepath": {
+ "type": "string"
+ },
+ "sourceMap": {
+ "type": "object",
+ "properties": {
+ "version": {
+ "type": "number"
+ },
+ "file": {
+ "type": "string"
+ },
+ "sources": {
+ "type": "array",
+ "items": {
+ "type": "string"
+ }
+ },
+ "sourcesContent": {
+ "type": "array",
+ "items": {
+ "type": "string"
+ }
+ },
+ "mappings": {
+ "type": "string"
+ },
+ "sourceRoot": {
+ "type": "string"
+ }
+ }
+ }
+ }
+ }
+ }
+ },
+ {
+ "$ref": "#/components/schemas/base_source_map_object"
+ }
+ ]
+ }
+ }
+ }
+ },
+ "501_response": {
+ "type": "object",
+ "properties": {
+ "statusCode": {
+ "type": "number",
+ "example": 501,
+ "description": "Error status code"
+ },
+ "error": {
+ "type": "string",
+ "example": "Not Implemented",
+ "description": "Error type"
+ },
+ "message": {
+ "type": "string",
+ "example": "Not Implemented",
+ "description": "Error message"
+ }
+ }
+ },
+ "upload_source_map_object": {
+ "type": "object",
+ "required": [
+ "service_name",
+ "service_version",
+ "bundle_filepath",
+ "sourcemap"
+ ],
+ "properties": {
+ "service_name": {
+ "type": "string",
+ "description": "The name of the service that the service map should apply to."
+ },
+ "service_version": {
+ "type": "string",
+ "description": "The version of the service that the service map should apply to."
+ },
+ "bundle_filepath": {
+ "type": "string",
+ "description": "The absolute path of the final bundle as used in the web application."
+ },
+ "sourcemap": {
+ "type": "string",
+ "format": "binary",
+ "description": "The source map. String or file upload. It must follow the\n[source map revision 3 proposal](https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k).\n"
+ }
+ }
+ },
+ "upload_source_maps_response": {
+ "allOf": [
+ {
+ "type": "object",
+ "properties": {
+ "body": {
+ "type": "string"
+ }
+ }
+ },
+ {
+ "$ref": "#/components/schemas/base_source_map_object"
+ }
+ ]
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.yaml
new file mode 100644
index 0000000000000..caa71f6645e77
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/bundled.yaml
@@ -0,0 +1,1162 @@
+openapi: 3.0.2
+info:
+ title: APM UI
+ version: 1.0.0
+tags:
+ - name: APM agent keys
+ description: |
+ Configure APM agent keys to authorize requests from APM agents to the APM Server.
+ - name: APM agent configuration
+ description: |
+ Adjust APM agent configuration without need to redeploy your application.
+ - name: APM sourcemaps
+ description: Configure APM source maps.
+ - name: APM annotations
+ description: |
+ Annotate visualizations in the APM app with significant events. Annotations enable you to easily see how events are impacting the performance of your applications.
+ - name: APM server schema
+ description: Create APM fleet server schema.
+paths:
+ /api/apm/agent_keys:
+ post:
+ summary: Create an APM agent key
+ description: Create a new agent key for APM.
+ operationId: createAgentKey
+ tags:
+ - APM agent keys
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/agent_keys_object'
+ responses:
+ '200':
+ description: Agent key created successfully
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/agent_keys_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/500_response'
+ /api/apm/services/{serviceName}/annotation/search:
+ get:
+ summary: Search for annotations
+ description: Search for annotations related to a specific service.
+ operationId: getAnnotation
+ tags:
+ - APM annotations
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - name: serviceName
+ in: path
+ required: true
+ description: The name of the service
+ schema:
+ type: string
+ - name: environment
+ in: query
+ required: false
+ description: The environment to filter annotations by
+ schema:
+ type: string
+ - name: start
+ in: query
+ required: false
+ description: The start date for the search
+ schema:
+ type: string
+ - name: end
+ in: query
+ required: false
+ description: The end date for the search
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/annotation_search_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/500_response'
+ /api/apm/services/{serviceName}/annotation:
+ post:
+ summary: Create a service annotation
+ description: Create a new annotation for a specific service.
+ operationId: createAnnotation
+ tags:
+ - APM annotations
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ - name: serviceName
+ in: path
+ required: true
+ description: The name of the service
+ schema:
+ type: string
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/create_annotation_object'
+ responses:
+ '200':
+ description: Annotation created successfully
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/create_annotation_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ /api/apm/settings/agent-configuration:
+ get:
+ summary: Get a list of agent configurations
+ operationId: getAgentConfigurations
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/agent_configurations_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ delete:
+ summary: Delete agent configuration
+ operationId: deleteAgentConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/service_object'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/delete_agent_configurations_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ put:
+ summary: Create or update agent configuration
+ operationId: createUpdateAgentConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ - name: overwrite
+ in: query
+ description: If the config exists ?overwrite=true is required
+ schema:
+ type: boolean
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/agent_configuration_intake_object'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ type: object
+ additionalProperties: false
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ /api/apm/settings/agent-configuration/view:
+ get:
+ summary: Get single agent configuration
+ operationId: getSingleAgentConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - name: name
+ in: query
+ description: Service name
+ schema:
+ type: string
+ example: node
+ - name: environment
+ in: query
+ description: Service environment
+ schema:
+ type: string
+ example: prod
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/single_agent_configuration_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ /api/apm/settings/agent-configuration/search:
+ post:
+ summary: Lookup single agent configuration
+ description: |
+ This endpoint allows to search for single agent configuration and update 'applied_by_agent' field.
+ operationId: searchSingleConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/search_agent_configuration_object'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/search_agent_configuration_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ /api/apm/settings/agent-configuration/environments:
+ get:
+ summary: Get environments for service
+ operationId: getEnvironmentsForService
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - name: serviceName
+ in: query
+ description: The name of the service
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/service_environments_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ /api/apm/settings/agent-configuration/agent_name:
+ get:
+ summary: Get agent name for service
+ description: Retrieve `agentName` for a service.
+ operationId: getAgentNameForService
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - name: serviceName
+ in: query
+ description: The name of the service
+ required: true
+ schema:
+ type: string
+ example: node
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/service_agent_name_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+ /api/apm/sourcemaps:
+ get:
+ summary: Get source maps
+ description: Returns an array of Fleet artifacts, including source map uploads.
+ operationId: getSourceMaps
+ tags:
+ - APM sourcemaps
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - name: page
+ in: query
+ description: Page number
+ schema:
+ type: number
+ - name: perPage
+ in: query
+ description: Number of records per page
+ schema:
+ type: number
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/source_maps_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/500_response'
+ '501':
+ description: Not Implemented response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/501_response'
+ post:
+ summary: Upload source map
+ description: Upload a source map for a specific service and version.
+ operationId: uploadSourceMap
+ tags:
+ - APM sourcemaps
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ requestBody:
+ required: true
+ content:
+ multipart/form-data:
+ schema:
+ $ref: '#/components/schemas/upload_source_map_object'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/upload_source_maps_response'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/500_response'
+ '501':
+ description: Not Implemented response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/501_response'
+ /api/apm/sourcemaps/{id}:
+ delete:
+ summary: Delete source map
+ description: Delete a previously uploaded source map.
+ operationId: deleteSourceMap
+ tags:
+ - APM sourcemaps
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ - name: id
+ in: path
+ description: Source map identifier
+ required: true
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ type: object
+ additionalProperties: false
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/500_response'
+ '501':
+ description: Not Implemented response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/501_response'
+ /api/apm/fleet/apm_server_schema:
+ post:
+ summary: Save APM server schema
+ operationId: saveApmServerSchema
+ tags:
+ - APM server schema
+ parameters:
+ - $ref: '#/components/parameters/elastic_api_version'
+ - $ref: '#/components/parameters/kbn_xsrf'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ schema:
+ type: object
+ description: Schema object
+ additionalProperties: true
+ example:
+ foo: bar
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ type: object
+ additionalProperties: false
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/400_response'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/401_response'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/403_response'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/404_response'
+components:
+ parameters:
+ elastic_api_version:
+ description: The version of the API to use
+ in: header
+ name: elastic-api-version
+ required: true
+ schema:
+ default: '2023-10-31'
+ enum:
+ - '2023-10-31'
+ type: string
+ kbn_xsrf:
+ description: A required header to protect against CSRF attacks
+ in: header
+ name: kbn-xsrf
+ required: true
+ schema:
+ example: 'true'
+ type: string
+ schemas:
+ agent_keys_object:
+ type: object
+ required:
+ - name
+ - privileges
+ properties:
+ name:
+ type: string
+ description: Agent name
+ privileges:
+ type: array
+ description: Privileges configuration
+ items:
+ type: string
+ enum:
+ - event:write
+ - config_agent:read
+ agent_keys_response:
+ type: object
+ properties:
+ agentKey:
+ type: object
+ description: Agent key
+ required:
+ - id
+ - name
+ - api_key
+ - encoded
+ properties:
+ expiration:
+ type: integer
+ format: int64
+ id:
+ type: string
+ name:
+ type: string
+ api_key:
+ type: string
+ encoded:
+ type: string
+ 400_response:
+ type: object
+ properties:
+ statusCode:
+ type: number
+ example: 400
+ description: Error status code
+ error:
+ type: string
+ example: Not Found
+ description: Error type
+ message:
+ type: string
+ example: Not Found
+ description: Error message
+ 401_response:
+ type: object
+ properties:
+ statusCode:
+ type: number
+ example: 401
+ description: Error status code
+ error:
+ type: string
+ example: Unauthorized
+ description: Error type
+ message:
+ type: string
+ description: Error message
+ 403_response:
+ type: object
+ properties:
+ statusCode:
+ type: number
+ example: 403
+ description: Error status code
+ error:
+ type: string
+ example: Forbidden
+ description: Error type
+ message:
+ type: string
+ description: Error message
+ 500_response:
+ type: object
+ properties:
+ statusCode:
+ type: number
+ example: 500
+ description: Error status code
+ error:
+ type: string
+ example: Internal Server Error
+ description: Error type
+ message:
+ type: string
+ description: Error message
+ annotation_search_response:
+ type: object
+ properties:
+ annotations:
+ type: array
+ description: Annotations
+ items:
+ type: object
+ properties:
+ type:
+ type: string
+ enum:
+ - version
+ id:
+ type: string
+ '@timestamp':
+ type: number
+ text:
+ type: string
+ create_annotation_object:
+ type: object
+ required:
+ - '@timestamp'
+ - service
+ properties:
+ '@timestamp':
+ type: string
+ description: Timestamp
+ service:
+ type: object
+ description: Service
+ required:
+ - version
+ properties:
+ version:
+ type: string
+ environment:
+ type: string
+ message:
+ type: string
+ description: Message
+ tags:
+ type: array
+ description: Tags
+ items:
+ type: string
+ create_annotation_response:
+ type: object
+ properties:
+ _id:
+ type: string
+ description: Identifier
+ _index:
+ type: string
+ description: Index
+ _source:
+ type: object
+ description: Response
+ properties:
+ annotation:
+ type: object
+ properties:
+ type:
+ type: string
+ title:
+ type: string
+ tags:
+ type: array
+ items:
+ type: string
+ message:
+ type: string
+ service:
+ type: object
+ properties:
+ name:
+ type: string
+ environment:
+ type: string
+ version:
+ type: string
+ event:
+ type: object
+ properties:
+ created:
+ type: string
+ '@timestamp':
+ type: string
+ 404_response:
+ type: object
+ properties:
+ statusCode:
+ type: number
+ example: 404
+ description: Error status code
+ error:
+ type: string
+ example: Not Found
+ description: Error type
+ message:
+ type: string
+ example: Not Found
+ description: Error message
+ service_object:
+ type: object
+ description: Service
+ properties:
+ name:
+ type: string
+ example: node
+ description: Name
+ environment:
+ type: string
+ example: prod
+ description: Environment
+ settings_object:
+ type: object
+ description: Agent configuration settings
+ additionalProperties:
+ type: string
+ agent_configuration_object:
+ type: object
+ required:
+ - service
+ - settings
+ - '@timestamp'
+ - etag
+ description: Agent configuration
+ properties:
+ agent_name:
+ type: string
+ description: Agent name
+ service:
+ $ref: '#/components/schemas/service_object'
+ settings:
+ $ref: '#/components/schemas/settings_object'
+ '@timestamp':
+ type: number
+ example: 1730194190636
+ description: Timestamp
+ applied_by_agent:
+ type: boolean
+ example: true
+ description: Applied by agent
+ etag:
+ type: string
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ description: Etag
+ agent_configurations_response:
+ type: object
+ properties:
+ configurations:
+ type: array
+ description: Agent configuration
+ items:
+ $ref: '#/components/schemas/agent_configuration_object'
+ agent_configuration_intake_object:
+ type: object
+ required:
+ - service
+ - settings
+ properties:
+ agent_name:
+ type: string
+ description: Agent name
+ service:
+ $ref: '#/components/schemas/service_object'
+ settings:
+ $ref: '#/components/schemas/settings_object'
+ delete_agent_configurations_response:
+ type: object
+ properties:
+ result:
+ type: string
+ description: Result
+ single_agent_configuration_response:
+ allOf:
+ - type: object
+ required:
+ - id
+ properties:
+ id:
+ type: string
+ - $ref: '#/components/schemas/agent_configuration_object'
+ search_agent_configuration_object:
+ type: object
+ required:
+ - service
+ properties:
+ service:
+ $ref: '#/components/schemas/service_object'
+ etag:
+ type: string
+ description: If etags match then `applied_by_agent` field will be set to `true`
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ mark_as_applied_by_agent:
+ type: boolean
+ description: |
+ `markAsAppliedByAgent=true` means "force setting it to true regardless of etag".
+ This is needed for Jaeger agent that doesn't have etags
+ search_agent_configuration_response:
+ type: object
+ properties:
+ _index:
+ type: string
+ description: Index
+ _id:
+ type: string
+ description: Identifier
+ _score:
+ type: number
+ description: Score
+ _source:
+ $ref: '#/components/schemas/agent_configuration_object'
+ service_environment_object:
+ type: object
+ properties:
+ name:
+ type: string
+ example: ALL_OPTION_VALUE
+ description: Service environment name
+ alreadyConfigured:
+ type: boolean
+ description: Already configured
+ service_environments_response:
+ type: object
+ properties:
+ environments:
+ type: array
+ description: Service environment list
+ items:
+ $ref: '#/components/schemas/service_environment_object'
+ service_agent_name_response:
+ type: object
+ properties:
+ agentName:
+ type: string
+ description: Agent name
+ example: nodejs
+ base_source_map_object:
+ type: object
+ properties:
+ type:
+ type: string
+ description: Type
+ identifier:
+ type: string
+ description: Identifier
+ relative_url:
+ type: string
+ description: Relative URL
+ created:
+ type: string
+ description: Created date
+ id:
+ type: string
+ description: Identifier
+ compressionAlgorithm:
+ type: string
+ description: Compression Algorithm
+ decodedSha256:
+ type: string
+ description: Decoded SHA-256
+ decodedSize:
+ type: number
+ description: Decoded size
+ encodedSha256:
+ type: string
+ description: Encoded SHA-256
+ encodedSize:
+ type: number
+ description: Encoded size
+ encryptionAlgorithm:
+ type: string
+ description: Encryption Algorithm
+ packageName:
+ type: string
+ description: Package name
+ source_maps_response:
+ type: object
+ properties:
+ artifacts:
+ type: array
+ description: Artifacts
+ items:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: object
+ properties:
+ serviceName:
+ type: string
+ serviceVersion:
+ type: string
+ bundleFilepath:
+ type: string
+ sourceMap:
+ type: object
+ properties:
+ version:
+ type: number
+ file:
+ type: string
+ sources:
+ type: array
+ items:
+ type: string
+ sourcesContent:
+ type: array
+ items:
+ type: string
+ mappings:
+ type: string
+ sourceRoot:
+ type: string
+ - $ref: '#/components/schemas/base_source_map_object'
+ 501_response:
+ type: object
+ properties:
+ statusCode:
+ type: number
+ example: 501
+ description: Error status code
+ error:
+ type: string
+ example: Not Implemented
+ description: Error type
+ message:
+ type: string
+ example: Not Implemented
+ description: Error message
+ upload_source_map_object:
+ type: object
+ required:
+ - service_name
+ - service_version
+ - bundle_filepath
+ - sourcemap
+ properties:
+ service_name:
+ type: string
+ description: The name of the service that the service map should apply to.
+ service_version:
+ type: string
+ description: The version of the service that the service map should apply to.
+ bundle_filepath:
+ type: string
+ description: The absolute path of the final bundle as used in the web application.
+ sourcemap:
+ type: string
+ format: binary
+ description: |
+ The source map. String or file upload. It must follow the
+ [source map revision 3 proposal](https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k).
+ upload_source_maps_response:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: string
+ - $ref: '#/components/schemas/base_source_map_object'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/README.md b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/README.md
new file mode 100644
index 0000000000000..6beadcd86e1e9
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/README.md
@@ -0,0 +1,7 @@
+Reusable components
+===========
+
+ - `examples` - reusable [Example objects](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#example-object)
+ - `headers` - reusable [Header objects](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.2.md#header-object)
+ - `parameters` - reusable [Parameter objects](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.2.md#parameter-object)
+ - `schemas` - reusable [Schema objects](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.2.md#schema-object)
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/headers/elastic_api_version.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/headers/elastic_api_version.yaml
new file mode 100644
index 0000000000000..b11a093b7b581
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/headers/elastic_api_version.yaml
@@ -0,0 +1,9 @@
+description: The version of the API to use
+in: header
+name: elastic-api-version
+required: true
+schema:
+ default: '2023-10-31'
+ enum:
+ - '2023-10-31'
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/headers/kbn_xsrf.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/headers/kbn_xsrf.yaml
new file mode 100644
index 0000000000000..25fcd49c04e65
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/headers/kbn_xsrf.yaml
@@ -0,0 +1,7 @@
+description: A required header to protect against CSRF attacks
+in: header
+name: kbn-xsrf
+required: true
+schema:
+ example: 'true'
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/400_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/400_response.yaml
new file mode 100644
index 0000000000000..3f09203cd49d3
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/400_response.yaml
@@ -0,0 +1,14 @@
+type: object
+properties:
+ statusCode:
+ type: number
+ example: 400
+ description: Error status code
+ error:
+ type: string
+ example: Not Found
+ description: Error type
+ message:
+ type: string
+ example: Not Found
+ description: Error message
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/401_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/401_response.yaml
new file mode 100644
index 0000000000000..cf5afb3482e6c
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/401_response.yaml
@@ -0,0 +1,13 @@
+type: object
+properties:
+ statusCode:
+ type: number
+ example: 401
+ description: Error status code
+ error:
+ type: string
+ example: Unauthorized
+ description: Error type
+ message:
+ type: string
+ description: Error message
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/403_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/403_response.yaml
new file mode 100644
index 0000000000000..f04184dcb1bb2
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/403_response.yaml
@@ -0,0 +1,13 @@
+type: object
+properties:
+ statusCode:
+ type: number
+ example: 403
+ description: Error status code
+ error:
+ type: string
+ example: Forbidden
+ description: Error type
+ message:
+ type: string
+ description: Error message
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/404_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/404_response.yaml
new file mode 100644
index 0000000000000..9e539dcbda096
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/404_response.yaml
@@ -0,0 +1,14 @@
+type: object
+properties:
+ statusCode:
+ type: number
+ example: 404
+ description: Error status code
+ error:
+ type: string
+ example: Not Found
+ description: Error type
+ message:
+ type: string
+ example: Not Found
+ description: Error message
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/500_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/500_response.yaml
new file mode 100644
index 0000000000000..e952739138146
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/500_response.yaml
@@ -0,0 +1,13 @@
+type: object
+properties:
+ statusCode:
+ type: number
+ example: 500
+ description: Error status code
+ error:
+ type: string
+ example: Internal Server Error
+ description: Error type
+ message:
+ type: string
+ description: Error message
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/501_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/501_response.yaml
new file mode 100644
index 0000000000000..f5a1545f7183e
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/501_response.yaml
@@ -0,0 +1,14 @@
+type: object
+properties:
+ statusCode:
+ type: number
+ example: 501
+ description: Error status code
+ error:
+ type: string
+ example: Not Implemented
+ description: Error type
+ message:
+ type: string
+ example: Not Implemented
+ description: Error message
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configuration_intake_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configuration_intake_object.yaml
new file mode 100644
index 0000000000000..0be4a414cd35a
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configuration_intake_object.yaml
@@ -0,0 +1,12 @@
+type: object
+required:
+ - service
+ - settings
+properties:
+ agent_name:
+ type: string
+ description: Agent name
+ service:
+ $ref: 'service_object.yaml'
+ settings:
+ $ref: 'settings_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configuration_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configuration_object.yaml
new file mode 100644
index 0000000000000..8dfa922c25874
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configuration_object.yaml
@@ -0,0 +1,27 @@
+type: object
+required:
+ - service
+ - settings
+ - '@timestamp'
+ - etag
+description: Agent configuration
+properties:
+ agent_name:
+ type: string
+ description: Agent name
+ service:
+ $ref: 'service_object.yaml'
+ settings:
+ $ref: 'settings_object.yaml'
+ '@timestamp':
+ type: number
+ example: 1730194190636
+ description: Timestamp
+ applied_by_agent:
+ type: boolean
+ example: true
+ description: Applied by agent
+ etag:
+ type: string
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ description: Etag
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configurations_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configurations_response.yaml
new file mode 100644
index 0000000000000..a6bdb51466fb4
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_configurations_response.yaml
@@ -0,0 +1,7 @@
+type: object
+properties:
+ configurations:
+ type: array
+ description: Agent configuration
+ items:
+ $ref: 'agent_configuration_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_keys_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_keys_object.yaml
new file mode 100644
index 0000000000000..c5e248471db90
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_keys_object.yaml
@@ -0,0 +1,16 @@
+type: object
+required:
+ - name
+ - privileges
+properties:
+ name:
+ type: string
+ description: Agent name
+ privileges:
+ type: array
+ description: Privileges configuration
+ items:
+ type: string
+ enum:
+ - event:write
+ - config_agent:read
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_keys_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_keys_response.yaml
new file mode 100644
index 0000000000000..3507dae535faf
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/agent_keys_response.yaml
@@ -0,0 +1,22 @@
+type: object
+properties:
+ agentKey:
+ type: object
+ description: Agent key
+ required:
+ - id
+ - name
+ - api_key
+ - encoded
+ properties:
+ expiration:
+ type: integer
+ format: int64
+ id:
+ type: string
+ name:
+ type: string
+ api_key:
+ type: string
+ encoded:
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/annotation_search_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/annotation_search_response.yaml
new file mode 100644
index 0000000000000..7827f17ffb979
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/annotation_search_response.yaml
@@ -0,0 +1,18 @@
+type: object
+properties:
+ annotations:
+ type: array
+ description: Annotations
+ items:
+ type: object
+ properties:
+ type:
+ type: string
+ enum:
+ - version
+ id:
+ type: string
+ "@timestamp":
+ type: number
+ text:
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/base_source_map_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/base_source_map_object.yaml
new file mode 100644
index 0000000000000..f642c933f2b71
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/base_source_map_object.yaml
@@ -0,0 +1,38 @@
+type: object
+properties:
+ type:
+ type: string
+ description: Type
+ identifier:
+ type: string
+ description: Identifier
+ relative_url:
+ type: string
+ description: Relative URL
+ created:
+ type: string
+ description: Created date
+ id:
+ type: string
+ description: Identifier
+ compressionAlgorithm:
+ type: string
+ description: Compression Algorithm
+ decodedSha256:
+ type: string
+ description: Decoded SHA-256
+ decodedSize:
+ type: number
+ description: Decoded size
+ encodedSha256:
+ type: string
+ description: Encoded SHA-256
+ encodedSize:
+ type: number
+ description: Encoded size
+ encryptionAlgorithm:
+ type: string
+ description: Encryption Algorithm
+ packageName:
+ type: string
+ description: Package name
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/create_annotation_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/create_annotation_object.yaml
new file mode 100644
index 0000000000000..6a8f8ba9b96d0
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/create_annotation_object.yaml
@@ -0,0 +1,26 @@
+type: object
+required:
+ - '@timestamp'
+ - service
+properties:
+ '@timestamp':
+ type: string
+ description: Timestamp
+ service:
+ type: object
+ description: Service
+ required:
+ - version
+ properties:
+ version:
+ type: string
+ environment:
+ type: string
+ message:
+ type: string
+ description: Message
+ tags:
+ type: array
+ description: Tags
+ items:
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/create_annotation_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/create_annotation_response.yaml
new file mode 100644
index 0000000000000..4738406a1e765
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/create_annotation_response.yaml
@@ -0,0 +1,41 @@
+type: object
+properties:
+ _id:
+ type: string
+ description: Identifier
+ _index:
+ type: string
+ description: Index
+ _source:
+ type: object
+ description: Response
+ properties:
+ annotation:
+ type: object
+ properties:
+ type:
+ type: string
+ title:
+ type: string
+ tags:
+ type: array
+ items:
+ type: string
+ message:
+ type: string
+ service:
+ type: object
+ properties:
+ name:
+ type: string
+ environment:
+ type: string
+ version:
+ type: string
+ event:
+ type: object
+ properties:
+ created:
+ type: string
+ '@timestamp':
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/delete_agent_configurations_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/delete_agent_configurations_response.yaml
new file mode 100644
index 0000000000000..3dc7c58998b1f
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/delete_agent_configurations_response.yaml
@@ -0,0 +1,5 @@
+type: object
+properties:
+ result:
+ type: string
+ description: Result
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/search_agent_configuration_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/search_agent_configuration_object.yaml
new file mode 100644
index 0000000000000..abbbf91b77b89
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/search_agent_configuration_object.yaml
@@ -0,0 +1,15 @@
+type: object
+required:
+ - service
+properties:
+ service:
+ $ref: 'service_object.yaml'
+ etag:
+ type: string
+ description: If etags match then `applied_by_agent` field will be set to `true`
+ example: 0bc3b5ebf18fba8163fe4c96f491e3767a358f85
+ mark_as_applied_by_agent:
+ type: boolean
+ description: |
+ `markAsAppliedByAgent=true` means "force setting it to true regardless of etag".
+ This is needed for Jaeger agent that doesn't have etags
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/search_agent_configuration_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/search_agent_configuration_response.yaml
new file mode 100644
index 0000000000000..d0a5ff1d91a78
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/search_agent_configuration_response.yaml
@@ -0,0 +1,13 @@
+type: object
+properties:
+ _index:
+ type: string
+ description: Index
+ _id:
+ type: string
+ description: Identifier
+ _score:
+ type: number
+ description: Score
+ _source:
+ $ref: 'agent_configuration_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_agent_name_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_agent_name_response.yaml
new file mode 100644
index 0000000000000..b67c34b65df8e
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_agent_name_response.yaml
@@ -0,0 +1,6 @@
+type: object
+properties:
+ agentName:
+ type: string
+ description: Agent name
+ example: nodejs
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_environment_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_environment_object.yaml
new file mode 100644
index 0000000000000..0f7f11371e59c
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_environment_object.yaml
@@ -0,0 +1,9 @@
+type: object
+properties:
+ name:
+ type: string
+ example: ALL_OPTION_VALUE
+ description: Service environment name
+ alreadyConfigured:
+ type: boolean
+ description: Already configured
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_environments_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_environments_response.yaml
new file mode 100644
index 0000000000000..1b8cdc1cab48e
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_environments_response.yaml
@@ -0,0 +1,7 @@
+type: object
+properties:
+ environments:
+ type: array
+ description: Service environment list
+ items:
+ $ref: 'service_environment_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_object.yaml
new file mode 100644
index 0000000000000..c73dd8bc0eb19
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/service_object.yaml
@@ -0,0 +1,11 @@
+type: object
+description: Service
+properties:
+ name:
+ type: string
+ example: node
+ description: Name
+ environment:
+ type: string
+ example: prod
+ description: Environment
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/settings_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/settings_object.yaml
new file mode 100644
index 0000000000000..cf09f1b6254bd
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/settings_object.yaml
@@ -0,0 +1,4 @@
+type: object
+description: Agent configuration settings
+additionalProperties:
+ type: string
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/single_agent_configuration_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/single_agent_configuration_response.yaml
new file mode 100644
index 0000000000000..4ef312304cc60
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/single_agent_configuration_response.yaml
@@ -0,0 +1,8 @@
+allOf:
+ - type: object
+ required:
+ - id
+ properties:
+ id:
+ type: string
+ - $ref: 'agent_configuration_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/source_maps_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/source_maps_response.yaml
new file mode 100644
index 0000000000000..f5590110fecd2
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/source_maps_response.yaml
@@ -0,0 +1,38 @@
+type: object
+properties:
+ artifacts:
+ type: array
+ description: Artifacts
+ items:
+ allOf:
+ - type: object
+ properties:
+ body:
+ type: object
+ properties:
+ serviceName:
+ type: string
+ serviceVersion:
+ type: string
+ bundleFilepath:
+ type: string
+ sourceMap:
+ type: object
+ properties:
+ version:
+ type: number
+ file:
+ type: string
+ sources:
+ type: array
+ items:
+ type: string
+ sourcesContent:
+ type: array
+ items:
+ type: string
+ mappings:
+ type: string
+ sourceRoot:
+ type: string
+ - $ref: 'base_source_map_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/upload_source_map_object.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/upload_source_map_object.yaml
new file mode 100644
index 0000000000000..00483e3606df0
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/upload_source_map_object.yaml
@@ -0,0 +1,22 @@
+type: object
+required:
+ - service_name
+ - service_version
+ - bundle_filepath
+ - sourcemap
+properties:
+ service_name:
+ type: string
+ description: The name of the service that the service map should apply to.
+ service_version:
+ type: string
+ description: The version of the service that the service map should apply to.
+ bundle_filepath:
+ type: string
+ description: The absolute path of the final bundle as used in the web application.
+ sourcemap:
+ type: string
+ format: binary
+ description: |
+ The source map. String or file upload. It must follow the
+ [source map revision 3 proposal](https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k).
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/upload_source_maps_response.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/upload_source_maps_response.yaml
new file mode 100644
index 0000000000000..6b677374de4ab
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/components/schemas/upload_source_maps_response.yaml
@@ -0,0 +1,6 @@
+allOf:
+ - type: object
+ properties:
+ body:
+ type: string
+ - $ref: 'base_source_map_object.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/entrypoint.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/entrypoint.yaml
new file mode 100644
index 0000000000000..abb21fb980a9a
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/entrypoint.yaml
@@ -0,0 +1,42 @@
+openapi: 3.0.2
+info:
+ title: APM UI
+ version: 1.0.0
+tags:
+ - name: APM agent keys
+ description: >
+ Configure APM agent keys to authorize requests from APM agents to the APM Server.
+ - name: APM agent configuration
+ description: >
+ Adjust APM agent configuration without need to redeploy your application.
+ - name: APM sourcemaps
+ description: Configure APM source maps.
+ - name: APM annotations
+ description: >
+ Annotate visualizations in the APM app with significant events.
+ Annotations enable you to easily see how events are impacting the performance of your applications.
+ - name: APM server schema
+ description: Create APM fleet server schema.
+paths:
+ /api/apm/agent_keys:
+ $ref: 'paths/api@apm@agent_keys.yaml'
+ /api/apm/services/{serviceName}/annotation/search:
+ $ref: 'paths/api@apm@services@{service_name}@annotation@search.yaml'
+ /api/apm/services/{serviceName}/annotation:
+ $ref: 'paths/api@apm@services@{service_name}@annotation.yaml'
+ /api/apm/settings/agent-configuration:
+ $ref: 'paths/api@apm@settings@agent_configuration.yaml'
+ /api/apm/settings/agent-configuration/view:
+ $ref: 'paths/api@apm@settings@agent_configuration@view.yaml'
+ /api/apm/settings/agent-configuration/search:
+ $ref: 'paths/api@apm@settings@agent_configuration@search.yaml'
+ /api/apm/settings/agent-configuration/environments:
+ $ref: 'paths/api@apm@settings@agent_configuration@environments.yaml'
+ /api/apm/settings/agent-configuration/agent_name:
+ $ref: 'paths/api@apm@settings@agent_configuration@agent_name.yaml'
+ /api/apm/sourcemaps:
+ $ref: 'paths/api@apm@sourcemaps.yaml'
+ /api/apm/sourcemaps/{id}:
+ $ref: 'paths/api@apm@sourcemaps@{id}.yaml'
+ /api/apm/fleet/apm_server_schema:
+ $ref: 'paths/api@apm@fleet@apm_server_schema.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/README.md b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/README.md
new file mode 100644
index 0000000000000..b7818c8474fc8
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/README.md
@@ -0,0 +1,10 @@
+Paths
+=====
+
+Each path definition for which there is a specification exists within this folder.
+
+These files currently use the following conventions:
+
+* path separator token (e.g. `@`) is included in the file name
+* path parameter (e.g. `{example}`) is included in the file name
+* there is one file per path; each file can contain multiple operations
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@agent_keys.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@agent_keys.yaml
new file mode 100644
index 0000000000000..46b1588517761
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@agent_keys.yaml
@@ -0,0 +1,46 @@
+post:
+ summary: Create an APM agent key
+ description: Create a new agent key for APM.
+ operationId: createAgentKey
+ tags:
+ - APM agent keys
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/agent_keys_object.yaml'
+ responses:
+ "200":
+ description: Agent key created successfully
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/agent_keys_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/500_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@fleet@apm_server_schema.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@fleet@apm_server_schema.yaml
new file mode 100644
index 0000000000000..2c4629b44a211
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@fleet@apm_server_schema.yaml
@@ -0,0 +1,53 @@
+post:
+ summary: Save APM server schema
+ operationId: saveApmServerSchema
+ tags:
+ - APM server schema
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ schema:
+ type: object
+ description: Schema object
+ additionalProperties: true
+ example:
+ foo: "bar"
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ type: object
+ additionalProperties: false
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@services@{service_name}@annotation.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@services@{service_name}@annotation.yaml
new file mode 100644
index 0000000000000..3894bd6da2015
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@services@{service_name}@annotation.yaml
@@ -0,0 +1,52 @@
+post:
+ summary: Create a service annotation
+ description: Create a new annotation for a specific service.
+ operationId: createAnnotation
+ tags:
+ - APM annotations
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ - name: serviceName
+ in: path
+ required: true
+ description: The name of the service
+ schema:
+ type: string
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/create_annotation_object.yaml'
+ responses:
+ '200':
+ description: Annotation created successfully
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/create_annotation_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@services@{service_name}@annotation@search.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@services@{service_name}@annotation@search.yaml
new file mode 100644
index 0000000000000..0f1391be89806
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@services@{service_name}@annotation@search.yaml
@@ -0,0 +1,57 @@
+get:
+ summary: Search for annotations
+ description: Search for annotations related to a specific service.
+ operationId: getAnnotation
+ tags:
+ - APM annotations
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - name: serviceName
+ in: path
+ required: true
+ description: The name of the service
+ schema:
+ type: string
+ - name: environment
+ in: query
+ required: false
+ description: The environment to filter annotations by
+ schema:
+ type: string
+ - name: start
+ in: query
+ required: false
+ description: The start date for the search
+ schema:
+ type: string
+ - name: end
+ in: query
+ required: false
+ description: The end date for the search
+ schema:
+ type: string
+ responses:
+ "200":
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/annotation_search_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/500_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration.yaml
new file mode 100644
index 0000000000000..f508e855a3883
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration.yaml
@@ -0,0 +1,128 @@
+get:
+ summary: Get a list of agent configurations
+ operationId: getAgentConfigurations
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/agent_configurations_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
+delete:
+ summary: Delete agent configuration
+ operationId: deleteAgentConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/service_object.yaml'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/delete_agent_configurations_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
+put:
+ summary: Create or update agent configuration
+ operationId: createUpdateAgentConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ - name: overwrite
+ in: query
+ description: If the config exists ?overwrite=true is required
+ schema:
+ type: boolean
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/agent_configuration_intake_object.yaml'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ type: object
+ additionalProperties: false
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@agent_name.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@agent_name.yaml
new file mode 100644
index 0000000000000..4ad10fbb00833
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@agent_name.yaml
@@ -0,0 +1,40 @@
+get:
+ summary: Get agent name for service
+ description: Retrieve `agentName` for a service.
+ operationId: getAgentNameForService
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - name: serviceName
+ in: query
+ description: The name of the service
+ required: true
+ schema:
+ type: string
+ example: node
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/service_agent_name_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@environments.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@environments.yaml
new file mode 100644
index 0000000000000..c0791b92ac148
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@environments.yaml
@@ -0,0 +1,37 @@
+get:
+ summary: Get environments for service
+ operationId: getEnvironmentsForService
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - name: serviceName
+ in: query
+ description: The name of the service
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/service_environments_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@search.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@search.yaml
new file mode 100644
index 0000000000000..8ae4ce975fc08
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@search.yaml
@@ -0,0 +1,41 @@
+post:
+ summary: Lookup single agent configuration
+ description: |
+ This endpoint allows to search for single agent configuration and update 'applied_by_agent' field.
+ operationId: searchSingleConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/search_agent_configuration_object.yaml'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/search_agent_configuration_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@view.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@view.yaml
new file mode 100644
index 0000000000000..23e5cc2186d12
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@settings@agent_configuration@view.yaml
@@ -0,0 +1,44 @@
+get:
+ summary: Get single agent configuration
+ operationId: getSingleAgentConfiguration
+ tags:
+ - APM agent configuration
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - name: name
+ in: query
+ description: Service name
+ schema:
+ type: string
+ example: node
+ - name: environment
+ in: query
+ description: Service environment
+ schema:
+ type: string
+ example: prod
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/single_agent_configuration_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '404':
+ description: Not found response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/404_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@sourcemaps.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@sourcemaps.yaml
new file mode 100644
index 0000000000000..142cd0d2673c1
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@sourcemaps.yaml
@@ -0,0 +1,101 @@
+get:
+ summary: Get source maps
+ description: Returns an array of Fleet artifacts, including source map uploads.
+ operationId: getSourceMaps
+ tags:
+ - APM sourcemaps
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - name: page
+ in: query
+ description: Page number
+ schema:
+ type: number
+ - name: perPage
+ in: query
+ description: Number of records per page
+ schema:
+ type: number
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/source_maps_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/500_response.yaml'
+ '501':
+ description: Not Implemented response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/501_response.yaml'
+post:
+ summary: Upload source map
+ description: Upload a source map for a specific service and version.
+ operationId: uploadSourceMap
+ tags:
+ - APM sourcemaps
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ requestBody:
+ required: true
+ content:
+ multipart/form-data:
+ schema:
+ $ref: '../components/schemas/upload_source_map_object.yaml'
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/upload_source_maps_response.yaml'
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/500_response.yaml'
+ '501':
+ description: Not Implemented response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/501_response.yaml'
diff --git a/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@sourcemaps@{id}.yaml b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@sourcemaps@{id}.yaml
new file mode 100644
index 0000000000000..3f165360bf60c
--- /dev/null
+++ b/x-pack/plugins/observability_solution/apm/docs/openapi/apm/paths/api@apm@sourcemaps@{id}.yaml
@@ -0,0 +1,53 @@
+delete:
+ summary: Delete source map
+ description: Delete a previously uploaded source map.
+ operationId: deleteSourceMap
+ tags:
+ - APM sourcemaps
+ parameters:
+ - $ref: '../components/headers/elastic_api_version.yaml'
+ - $ref: '../components/headers/kbn_xsrf.yaml'
+ - name: id
+ in: path
+ description: Source map identifier
+ required: true
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Successful response
+ content:
+ application/json:
+ schema:
+ type: object
+ additionalProperties: false
+ '400':
+ description: Bad Request response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/400_response.yaml'
+ '401':
+ description: Unauthorized response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/401_response.yaml'
+ '403':
+ description: Forbidden response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/403_response.yaml'
+ '500':
+ description: Internal Server Error response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/500_response.yaml'
+ '501':
+ description: Not Implemented response
+ content:
+ application/json:
+ schema:
+ $ref: '../components/schemas/501_response.yaml'
diff --git a/x-pack/plugins/observability_solution/infra/public/apps/logs_app.tsx b/x-pack/plugins/observability_solution/infra/public/apps/logs_app.tsx
index 329e059288e3e..9d5583b0ecf4c 100644
--- a/x-pack/plugins/observability_solution/infra/public/apps/logs_app.tsx
+++ b/x-pack/plugins/observability_solution/infra/public/apps/logs_app.tsx
@@ -6,13 +6,19 @@
*/
import { History } from 'history';
-import { CoreStart } from '@kbn/core/public';
-import React from 'react';
+import { AppStatus, CoreStart } from '@kbn/core/public';
+import React, { useMemo } from 'react';
import ReactDOM from 'react-dom';
import { Router, Routes, Route } from '@kbn/shared-ux-router';
import { AppMountParameters } from '@kbn/core/public';
import { Storage } from '@kbn/kibana-utils-plugin/public';
-import { AllDatasetsLocatorParams, ALL_DATASETS_LOCATOR_ID } from '@kbn/deeplinks-observability';
+import {
+ AllDatasetsLocatorParams,
+ ALL_DATASETS_LOCATOR_ID,
+ OBSERVABILITY_LOGS_EXPLORER_APP_ID,
+} from '@kbn/deeplinks-observability';
+import useObservable from 'react-use/lib/useObservable';
+import { map } from 'rxjs';
import { LinkToLogsPage } from '../pages/link_to/link_to_logs';
import { LogsPage } from '../pages/logs';
import { InfraClientStartDeps, InfraClientStartExports } from '../types';
@@ -57,7 +63,22 @@ const LogsApp: React.FC<{
storage: Storage;
theme$: AppMountParameters['theme$'];
}> = ({ core, history, pluginStart, plugins, setHeaderActionMenu, storage, theme$ }) => {
- const { logs, discover, fleet } = core.application.capabilities;
+ const { logs } = core.application.capabilities;
+
+ const isLogsExplorerAppAccessible = useObservable(
+ useMemo(
+ () =>
+ core.application.applications$.pipe(
+ map(
+ (apps) =>
+ (apps.get(OBSERVABILITY_LOGS_EXPLORER_APP_ID)?.status ?? AppStatus.inaccessible) ===
+ AppStatus.accessible
+ )
+ ),
+ [core.application.applications$]
+ ),
+ false
+ );
return (
@@ -74,7 +95,7 @@ const LogsApp: React.FC<{
toastsService={core.notifications.toasts}
>
- {Boolean(discover?.show && fleet?.read) && (
+ {isLogsExplorerAppAccessible && (
+ combineLatest([of(application), getLogsExplorerAccessible$(application)])
+ )
+ );
const logRoutes = getLogsAppRoutes({ isLogsStreamEnabled });
/** !! Need to be kept in sync with the deepLinks in x-pack/plugins/observability_solution/infra/public/plugin.ts */
pluginsSetup.observabilityShared.navigation.registerSections(
- startDep$AndHostViewFlag$.pipe(
- map(([[{ application }]]) => {
+ startDep$AndAccessibleFlag$.pipe(
+ map(([application, isLogsExplorerAccessible]) => {
const { infrastructure, logs } = application.capabilities;
return [
...(logs.show
@@ -148,7 +159,7 @@ export class Plugin implements InfraClientPluginClass {
label: logsTitle,
sortKey: 200,
entries: getLogsNavigationEntries({
- application,
+ isLogsExplorerAccessible,
config: this.config,
routes: logRoutes,
}),
@@ -310,16 +321,13 @@ export class Plugin implements InfraClientPluginClass {
);
},
});
-
- startDep$AndHostViewFlag$.subscribe(
- ([_startServices]: [[CoreStart, InfraClientStartDeps, InfraClientStartExports]]) => {
- this.appUpdater$.next(() => ({
- deepLinks: getInfraDeepLinks({
- metricsExplorerEnabled: this.config.featureFlags.metricsExplorerEnabled,
- }),
- }));
- }
- );
+ startDep$AndAccessibleFlag$.subscribe(([_applicationStart, _isLogsExplorerAccessible]) => {
+ this.appUpdater$.next(() => ({
+ deepLinks: getInfraDeepLinks({
+ metricsExplorerEnabled: this.config.featureFlags.metricsExplorerEnabled,
+ }),
+ }));
+ });
// Setup telemetry events
this.telemetry.setup({ analytics: core.analytics });
@@ -382,11 +390,11 @@ export class Plugin implements InfraClientPluginClass {
}
const getLogsNavigationEntries = ({
- application,
+ isLogsExplorerAccessible,
config,
routes,
}: {
- application: CoreStart['application'];
+ isLogsExplorerAccessible: boolean;
config: InfraPublicConfig;
routes: LogsAppRoutes;
}) => {
@@ -394,16 +402,14 @@ const getLogsNavigationEntries = ({
if (!config.featureFlags.logsUIEnabled) return entries;
- getLogsExplorerAccessibility$(application).subscribe((isAccessible) => {
- if (isAccessible) {
- entries.push({
- label: 'Explorer',
- app: 'observability-logs-explorer',
- path: '/',
- isBetaFeature: true,
- });
- }
- });
+ if (isLogsExplorerAccessible) {
+ entries.push({
+ label: 'Explorer',
+ app: 'observability-logs-explorer',
+ path: '/',
+ isBetaFeature: true,
+ });
+ }
// Display Stream nav entry when Logs Stream is enabled
if (routes.stream) entries.push(createNavEntryFromRoute(routes.stream));
@@ -416,16 +422,15 @@ const getLogsNavigationEntries = ({
return entries;
};
-const getLogsExplorerAccessibility$ = (application: CoreStart['application']) => {
- const { capabilities, applications$ } = application;
+const getLogsExplorerAccessible$ = (application: CoreStart['application']) => {
+ const { applications$ } = application;
return applications$.pipe(
map(
(apps) =>
(apps.get(OBSERVABILITY_LOGS_EXPLORER_APP_ID)?.status ?? AppStatus.inaccessible) ===
- AppStatus.accessible &&
- capabilities.discover?.show &&
- capabilities.fleet?.read
- )
+ AppStatus.accessible
+ ),
+ distinctUntilChanged()
);
};
diff --git a/x-pack/plugins/observability_solution/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.test.ts b/x-pack/plugins/observability_solution/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.test.ts
index c54b29d52714f..a29308774440c 100644
--- a/x-pack/plugins/observability_solution/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.test.ts
+++ b/x-pack/plugins/observability_solution/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.test.ts
@@ -6,14 +6,7 @@
*/
import rison from '@kbn/rison';
-import {
- AlertInstanceContext as AlertContext,
- AlertInstanceState as AlertState,
-} from '@kbn/alerting-plugin/server';
import { RuleExecutorServicesMock, alertsMock } from '@kbn/alerting-plugin/server/mocks';
-import { LifecycleAlertServices } from '@kbn/rule-registry-plugin/server';
-import { ruleRegistryMocks } from '@kbn/rule-registry-plugin/server/mocks';
-import { createLifecycleRuleExecutorMock } from '@kbn/rule-registry-plugin/server/utils/create_lifecycle_rule_executor_mock';
import { COMPARATORS } from '@kbn/alerting-comparators';
import { Aggregators, InventoryMetricConditions } from '../../../../common/alerting/metrics';
import type { LogMeta, Logger } from '@kbn/logging';
@@ -150,9 +143,7 @@ const mockLibs = {
infraPluginMock.createStartContract(),
],
configuration: createMockStaticConfiguration({}),
- metricsRules: {
- createLifecycleRuleExecutor: createLifecycleRuleExecutorMock,
- },
+ metricsRules: {},
basePath: {
publicBaseUrl: 'http://localhost:5601',
prepend: (path: string) => path,
@@ -165,14 +156,10 @@ const mockLibs = {
logger,
} as unknown as InfraBackendLibs;
const alerts = new Map();
-let services: RuleExecutorServicesMock & LifecycleAlertServices;
+let services: RuleExecutorServicesMock;
const setup = () => {
- const alertsServices = alertsMock.createRuleExecutorServices();
- services = {
- ...alertsServices,
- ...ruleRegistryMocks.createLifecycleAlertServices(alertsServices),
- };
+ services = alertsMock.createRuleExecutorServices();
services.alertsClient.report.mockImplementation((params: any) => {
alerts.set(params.id, { actionGroup: params.actionGroup, context: [], payload: [] });
diff --git a/x-pack/plugins/observability_solution/infra/server/services/rules/rules_service.ts b/x-pack/plugins/observability_solution/infra/server/services/rules/rules_service.ts
index 85d3d8548fbe6..99e7c57d857b5 100644
--- a/x-pack/plugins/observability_solution/infra/server/services/rules/rules_service.ts
+++ b/x-pack/plugins/observability_solution/infra/server/services/rules/rules_service.ts
@@ -6,7 +6,6 @@
*/
import { CoreSetup, Logger } from '@kbn/core/server';
-import { createLifecycleExecutor } from '@kbn/rule-registry-plugin/server';
import { InfraFeatureId } from '../../../common/constants';
import { createRuleDataClient } from './rule_data_client';
import {
@@ -36,12 +35,7 @@ export class RulesService {
ruleDataService: setupDeps.ruleRegistry.ruleDataService,
});
- const createLifecycleRuleExecutor = createLifecycleExecutor(this.logger, ruleDataClient);
-
- return {
- createLifecycleRuleExecutor,
- ruleDataClient,
- };
+ return { ruleDataClient };
}
public start(_startDeps: RulesServiceStartDeps): RulesServiceStart {
diff --git a/x-pack/plugins/observability_solution/infra/server/services/rules/types.ts b/x-pack/plugins/observability_solution/infra/server/services/rules/types.ts
index fa14089de2ba5..68ae0bd95b410 100644
--- a/x-pack/plugins/observability_solution/infra/server/services/rules/types.ts
+++ b/x-pack/plugins/observability_solution/infra/server/services/rules/types.ts
@@ -6,13 +6,7 @@
*/
import { PluginSetupContract as AlertingPluginSetup } from '@kbn/alerting-plugin/server';
-import {
- createLifecycleExecutor,
- IRuleDataClient,
- RuleRegistryPluginSetupContract,
-} from '@kbn/rule-registry-plugin/server';
-
-type LifecycleRuleExecutorCreator = ReturnType;
+import { IRuleDataClient, RuleRegistryPluginSetupContract } from '@kbn/rule-registry-plugin/server';
export interface RulesServiceSetupDeps {
alerting: AlertingPluginSetup;
ruleRegistry: RuleRegistryPluginSetupContract;
@@ -22,7 +16,6 @@ export interface RulesServiceSetupDeps {
export interface RulesServiceStartDeps {}
export interface RulesServiceSetup {
- createLifecycleRuleExecutor: LifecycleRuleExecutorCreator;
ruleDataClient: IRuleDataClient;
}
diff --git a/x-pack/plugins/observability_solution/observability_ai_assistant/public/components/insight/insight.tsx b/x-pack/plugins/observability_solution/observability_ai_assistant/public/components/insight/insight.tsx
index 562749f24cc9d..e5168470be8f1 100644
--- a/x-pack/plugins/observability_solution/observability_ai_assistant/public/components/insight/insight.tsx
+++ b/x-pack/plugins/observability_solution/observability_ai_assistant/public/components/insight/insight.tsx
@@ -128,6 +128,7 @@ function ChatContent({
service.conversations.openNewConversation({
messages,
title: defaultTitle,
+ hideConversationList: true,
});
}}
/>
diff --git a/x-pack/plugins/observability_solution/observability_ai_assistant/public/service/create_service.ts b/x-pack/plugins/observability_solution/observability_ai_assistant/public/service/create_service.ts
index 07f967a4028d9..5b64073592430 100644
--- a/x-pack/plugins/observability_solution/observability_ai_assistant/public/service/create_service.ts
+++ b/x-pack/plugins/observability_solution/observability_ai_assistant/public/service/create_service.ts
@@ -36,7 +36,11 @@ export function createService({
const screenContexts$ = new BehaviorSubject([
{ starterPrompts: defaultStarterPrompts },
]);
- const predefinedConversation$ = new Subject<{ messages: Message[]; title?: string }>();
+ const predefinedConversation$ = new Subject<{
+ messages: Message[];
+ title?: string;
+ hideConversationList?: boolean;
+ }>();
const scope$ = new BehaviorSubject(scopes);
@@ -104,8 +108,16 @@ export function createService({
);
},
conversations: {
- openNewConversation: ({ messages, title }: { messages: Message[]; title?: string }) => {
- predefinedConversation$.next({ messages, title });
+ openNewConversation: ({
+ messages,
+ title,
+ hideConversationList = false,
+ }: {
+ messages: Message[];
+ title?: string;
+ hideConversationList?: boolean;
+ }) => {
+ predefinedConversation$.next({ messages, title, hideConversationList });
},
predefinedConversation$: predefinedConversation$.asObservable(),
},
diff --git a/x-pack/plugins/observability_solution/observability_ai_assistant/public/types.ts b/x-pack/plugins/observability_solution/observability_ai_assistant/public/types.ts
index becc21f59c5f4..72517df5bffbc 100644
--- a/x-pack/plugins/observability_solution/observability_ai_assistant/public/types.ts
+++ b/x-pack/plugins/observability_solution/observability_ai_assistant/public/types.ts
@@ -91,8 +91,16 @@ export interface ObservabilityAIAssistantChatService {
}
export interface ObservabilityAIAssistantConversationService {
- openNewConversation: ({}: { messages: Message[]; title?: string }) => void;
- predefinedConversation$: Observable<{ messages: Message[]; title?: string }>;
+ openNewConversation: ({}: {
+ messages: Message[];
+ title?: string;
+ hideConversationList?: boolean;
+ }) => void;
+ predefinedConversation$: Observable<{
+ messages: Message[];
+ title?: string;
+ hideConversationList?: boolean;
+ }>;
}
export interface ObservabilityAIAssistantService {
diff --git a/x-pack/plugins/observability_solution/observability_ai_assistant_app/public/components/nav_control/index.tsx b/x-pack/plugins/observability_solution/observability_ai_assistant_app/public/components/nav_control/index.tsx
index 883317c02274f..b6095ac595cea 100644
--- a/x-pack/plugins/observability_solution/observability_ai_assistant_app/public/components/nav_control/index.tsx
+++ b/x-pack/plugins/observability_solution/observability_ai_assistant_app/public/components/nav_control/index.tsx
@@ -103,9 +103,12 @@ export function NavControl() {
};
}, [service.conversations.predefinedConversation$]);
- const { messages, title } = useObservable(service.conversations.predefinedConversation$) ?? {
+ const { messages, title, hideConversationList } = useObservable(
+ service.conversations.predefinedConversation$
+ ) ?? {
messages: [],
title: undefined,
+ hideConversationList: false,
};
const theme = useTheme();
@@ -171,6 +174,7 @@ export function NavControl() {
)
);
}}
+ hideConversationList={hideConversationList}
/>
) : undefined}
diff --git a/x-pack/plugins/observability_solution/slo/public/pages/slo_edit/components/common/query_search_bar.tsx b/x-pack/plugins/observability_solution/slo/public/pages/slo_edit/components/common/query_search_bar.tsx
index d238aacf1df60..394d8c303e953 100644
--- a/x-pack/plugins/observability_solution/slo/public/pages/slo_edit/components/common/query_search_bar.tsx
+++ b/x-pack/plugins/observability_solution/slo/public/pages/slo_edit/components/common/query_search_bar.tsx
@@ -69,7 +69,7 @@ export const QuerySearchBar = memo(
field.onChange(String(value?.query));
} else {
field.onChange({
- ...(field.value ?? {}),
+ filters: field.value?.filters ?? [],
kqlQuery: String(value?.query),
});
}
@@ -111,15 +111,27 @@ export const QuerySearchBar = memo(
}
onQuerySubmit={(value) => handleQueryChange(value.query, value.dateRange)}
onFiltersUpdated={(filters) => {
+ const updatedFilters = filters.map((filter) => {
+ const { $state, meta, ...rest } = filter;
+ const query = filter?.query ? { ...filter.query } : { ...rest };
+ return {
+ meta: {
+ ...meta,
+ alias: meta?.alias ?? JSON.stringify(query),
+ },
+ query,
+ };
+ });
+
if (kqlQuerySchema.is(field.value)) {
field.onChange({
- filters,
+ filters: updatedFilters,
kqlQuery: field.value,
});
} else {
field.onChange({
- ...(field.value ?? {}),
- filters,
+ kqlQuery: field.value?.kqlQuery ?? '',
+ filters: updatedFilters,
});
}
}}
diff --git a/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.test.ts b/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.test.ts
index 40aec3b468a37..18c4bf71cdfec 100644
--- a/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.test.ts
+++ b/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.test.ts
@@ -70,6 +70,9 @@ describe('mergeSourceMonitor', () => {
const result = mapSavedObjectToMonitor({ monitor: { attributes: testMonitor } } as any);
expect(result).toEqual({
+ __ui: {
+ is_tls_enabled: false,
+ },
alert: {
status: {
enabled: true,
@@ -78,53 +81,48 @@ describe('mergeSourceMonitor', () => {
enabled: true,
},
},
+ 'check.request.method': 'GET',
+ 'check.response.status': ['404'],
config_id: 'ae88f0aa-9c7d-4a5f-96dc-89d65a0ca947',
custom_heartbeat_id: 'todos-lightweight-test-projects-default',
enabled: true,
id: 'todos-lightweight-test-projects-default',
ipv4: true,
ipv6: true,
- locations: ['us_central', 'us_east'],
- private_locations: ['pvt_us_east'],
- max_redirects: 0,
+ locations: [
+ {
+ geo: {
+ lat: 41.25,
+ lon: -95.86,
+ },
+ id: 'us_central',
+ isServiceManaged: true,
+ label: 'North America - US Central',
+ },
+ ],
+ max_attempts: 2,
+ max_redirects: '0',
mode: 'any',
name: 'Todos Lightweight',
namespace: 'default',
+ origin: 'project',
original_space: 'default',
- proxy_url: '',
+ project_id: 'test-projects',
+ 'response.include_body': 'on_error',
+ 'response.include_body_max_bytes': '1024',
+ 'response.include_headers': true,
retest_on_failure: true,
revision: 21,
schedule: {
number: '3',
unit: 'm',
},
- 'service.name': '',
- tags: [],
+ 'ssl.key': 'test-key',
+ 'ssl.supported_protocols': ['TLSv1.1', 'TLSv1.2', 'TLSv1.3'],
+ 'ssl.verification_mode': 'full',
timeout: '16',
type: 'http',
url: '${devUrl}',
- 'url.port': null,
- ssl: {
- certificate: '',
- certificate_authorities: '',
- supported_protocols: ['TLSv1.1', 'TLSv1.2', 'TLSv1.3'],
- verification_mode: 'full',
- key: 'test-key',
- },
- response: {
- include_body: 'on_error',
- include_body_max_bytes: '1024',
- include_headers: true,
- },
- check: {
- request: {
- method: 'GET',
- },
- response: {
- status: ['404'],
- },
- },
- params: {},
});
});
@@ -157,30 +155,12 @@ describe('mergeSourceMonitor', () => {
locations: [
{
geo: {
- lon: -95.86,
lat: 41.25,
- },
- isServiceManaged: true,
- id: 'us_central',
- label: 'North America - US Central',
- },
- {
- geo: {
lon: -95.86,
- lat: 41.25,
},
+ id: 'us_central',
isServiceManaged: true,
- id: 'us-east4-a',
- label: 'US East',
- },
- {
- geo: {
- lon: -95.86,
- lat: 41.25,
- },
- isServiceManaged: false,
- id: 'pvt_us_east',
- label: 'US East (Private)',
+ label: 'North America - US Central',
},
],
max_redirects: '0',
@@ -249,24 +229,6 @@ const testMonitor = {
id: 'us_central',
label: 'North America - US Central',
},
- {
- geo: {
- lon: -95.86,
- lat: 41.25,
- },
- isServiceManaged: true,
- id: 'us-east4-a',
- label: 'US East',
- },
- {
- geo: {
- lon: -95.86,
- lat: 41.25,
- },
- isServiceManaged: false,
- id: 'pvt_us_east',
- label: 'US East (Private)',
- },
],
namespace: 'default',
origin: 'project',
diff --git a/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.ts b/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.ts
index 06746fc235769..4156620abdd78 100644
--- a/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.ts
+++ b/x-pack/plugins/observability_solution/synthetics/server/routes/monitor_cruds/formatters/saved_object_to_monitor.ts
@@ -7,7 +7,6 @@
import { SavedObject } from '@kbn/core/server';
import { mergeWith, omit, omitBy } from 'lodash';
-import { LocationsMap } from '../../../synthetics_service/project_monitor/normalizers/common_fields';
import {
ConfigKey,
EncryptedSyntheticsMonitor,
@@ -22,14 +21,6 @@ const keysToOmit = [
ConfigKey.CONFIG_HASH,
ConfigKey.JOURNEY_ID,
ConfigKey.FORM_MONITOR_TYPE,
- ConfigKey.MAX_ATTEMPTS,
- ConfigKey.MONITOR_SOURCE_TYPE,
- ConfigKey.METADATA,
- ConfigKey.SOURCE_PROJECT_CONTENT,
- ConfigKey.PROJECT_ID,
- ConfigKey.JOURNEY_FILTERS_MATCH,
- ConfigKey.JOURNEY_FILTERS_TAGS,
- ConfigKey.MONITOR_SOURCE_TYPE,
];
type Result = MonitorFieldsResult & {
@@ -39,14 +30,25 @@ type Result = MonitorFieldsResult & {
ssl: Record;
response: Record;
check: Record;
- locations: string[];
- private_locations: string[];
};
export const transformPublicKeys = (result: Result) => {
+ if (result[ConfigKey.SOURCE_INLINE]) {
+ result.inline_script = result[ConfigKey.SOURCE_INLINE];
+ }
+ if (result[ConfigKey.HOSTS]) {
+ result.host = result[ConfigKey.HOSTS];
+ }
+ if (result[ConfigKey.PARAMS]) {
+ try {
+ result[ConfigKey.PARAMS] = JSON.parse(result[ConfigKey.PARAMS] ?? '{}');
+ } catch (e) {
+ // ignore
+ }
+ }
+
let formattedResult = {
...result,
- ...formatLocations(result),
[ConfigKey.PARAMS]: formatParams(result),
retest_on_failure: (result[ConfigKey.MAX_ATTEMPTS] ?? 1) > 1,
...(result[ConfigKey.HOSTS] && { host: result[ConfigKey.HOSTS] }),
@@ -58,20 +60,8 @@ export const transformPublicKeys = (result: Result) => {
...(result[ConfigKey.SOURCE_INLINE] && { inline_script: result[ConfigKey.SOURCE_INLINE] }),
[ConfigKey.PLAYWRIGHT_OPTIONS]: formatPWOptions(result),
};
- } else {
- formattedResult.ssl = formatNestedFields(formattedResult, 'ssl');
- formattedResult.response = formatNestedFields(formattedResult, 'response');
- formattedResult.check = formatNestedFields(formattedResult, 'check');
- if (formattedResult[ConfigKey.MAX_REDIRECTS]) {
- formattedResult[ConfigKey.MAX_REDIRECTS] = Number(formattedResult[ConfigKey.MAX_REDIRECTS]);
- }
}
- const res = omit(formattedResult, keysToOmit) as Result;
-
- return omitBy(
- res,
- (_, key) => key.startsWith('response.') || key.startsWith('ssl.') || key.startsWith('check.')
- );
+ return omit(formattedResult, keysToOmit) as Result;
};
export function mapSavedObjectToMonitor({
@@ -81,7 +71,7 @@ export function mapSavedObjectToMonitor({
monitor: SavedObject;
internal?: boolean;
}) {
- const result = {
+ let result = {
...monitor.attributes,
created_at: monitor.created_at,
updated_at: monitor.updated_at,
@@ -89,7 +79,9 @@ export function mapSavedObjectToMonitor({
if (internal) {
return result;
}
- return transformPublicKeys(result);
+ result = transformPublicKeys(result);
+ // omit undefined value or null value
+ return omitBy(result, removeMonitorEmptyValues);
}
export function mergeSourceMonitor(
normalizedPreviousMonitor: EncryptedSyntheticsMonitor,
@@ -108,24 +100,6 @@ const customizer = (destVal: any, srcValue: any, key: string) => {
}
};
-const formatLocations = (config: MonitorFields) => {
- const locMap = Object.entries(LocationsMap);
- const locations = config[ConfigKey.LOCATIONS]
- ?.filter((location) => location.isServiceManaged)
- .map((location) => {
- return locMap.find(([_key, value]) => value === location.id)?.[0] ?? location.id;
- });
-
- const privateLocations = config[ConfigKey.LOCATIONS]
- ?.filter((location) => !location.isServiceManaged)
- .map((location) => location.id);
-
- return {
- ...(locations && { locations }),
- ...(privateLocations && { private_locations: privateLocations }),
- };
-};
-
const formatParams = (config: MonitorFields) => {
if (config[ConfigKey.PARAMS]) {
try {
@@ -177,3 +151,17 @@ const formatNestedFields = (
return obj;
};
+
+export const removeMonitorEmptyValues = (v: any) => {
+ // value is falsy
+ return (
+ v === undefined ||
+ v === null ||
+ // value is empty string
+ (typeof v === 'string' && v.trim() === '') ||
+ // is empty array
+ (Array.isArray(v) && v.length === 0) ||
+ // object is has no values
+ (typeof v === 'object' && Object.keys(v).length === 0)
+ );
+};
diff --git a/x-pack/plugins/osquery/cypress/e2e/roles/alert_test.cy.ts b/x-pack/plugins/osquery/cypress/e2e/roles/alert_test.cy.ts
index b332951b1a444..2eaf015f23220 100644
--- a/x-pack/plugins/osquery/cypress/e2e/roles/alert_test.cy.ts
+++ b/x-pack/plugins/osquery/cypress/e2e/roles/alert_test.cy.ts
@@ -5,6 +5,7 @@
* 2.0.
*/
+import { waitForAlertsToPopulate } from '@kbn/test-suites-xpack/security_solution_cypress/cypress/tasks/create_new_rule';
import { disableNewFeaturesTours } from '../../tasks/navigation';
import { initializeDataViews } from '../../tasks/login';
import { checkResults, clickRuleName, submitQuery } from '../../tasks/live_query';
@@ -31,9 +32,8 @@ describe('Alert Test', { tags: ['@ess'] }, () => {
onBeforeLoad: (win) => disableNewFeaturesTours(win),
});
clickRuleName(ruleName);
- cy.getBySel('expand-event').first().click({ force: true });
-
- cy.wait(500);
+ waitForAlertsToPopulate();
+ cy.getBySel('expand-event').first().click();
cy.getBySel('securitySolutionFlyoutInvestigationGuideButton').click();
cy.contains('Get processes').click();
});
diff --git a/x-pack/plugins/rule_registry/server/index.ts b/x-pack/plugins/rule_registry/server/index.ts
index 826d0d6f23bab..de0685b8c9617 100644
--- a/x-pack/plugins/rule_registry/server/index.ts
+++ b/x-pack/plugins/rule_registry/server/index.ts
@@ -25,13 +25,6 @@ export * from './rule_data_plugin_service';
export * from './rule_data_client';
export * from './alert_data_client/audit_events';
-export { createLifecycleRuleTypeFactory } from './utils/create_lifecycle_rule_type_factory';
-export type {
- LifecycleRuleExecutor,
- LifecycleAlertService,
- LifecycleAlertServices,
-} from './utils/create_lifecycle_executor';
-export { createLifecycleExecutor } from './utils/create_lifecycle_executor';
export { createPersistenceRuleTypeWrapper } from './utils/create_persistence_rule_type_wrapper';
export * from './utils/persistence_types';
export type { AlertsClient } from './alert_data_client/alerts_client';
diff --git a/x-pack/plugins/rule_registry/server/mocks.ts b/x-pack/plugins/rule_registry/server/mocks.ts
index 7ab1391ca1dec..ef5ae00ca0c56 100644
--- a/x-pack/plugins/rule_registry/server/mocks.ts
+++ b/x-pack/plugins/rule_registry/server/mocks.ts
@@ -11,10 +11,8 @@ import {
ruleDataServiceMock,
RuleDataServiceMock,
} from './rule_data_plugin_service/rule_data_plugin_service.mock';
-import { createLifecycleAlertServicesMock } from './utils/lifecycle_alert_services.mock';
export const ruleRegistryMocks = {
- createLifecycleAlertServices: createLifecycleAlertServicesMock,
createRuleDataService: ruleDataServiceMock.create,
createRuleDataClient: createRuleDataClientMock,
createAlertsClientMock: alertsClientMock,
diff --git a/x-pack/plugins/rule_registry/server/plugin.ts b/x-pack/plugins/rule_registry/server/plugin.ts
index 7f6b6e0bf6002..60ee2256ae377 100644
--- a/x-pack/plugins/rule_registry/server/plugin.ts
+++ b/x-pack/plugins/rule_registry/server/plugin.ts
@@ -29,7 +29,6 @@ import type {
PluginSetup as DataPluginSetup,
} from '@kbn/data-plugin/server';
-import { createLifecycleRuleTypeFactory } from './utils/create_lifecycle_rule_type_factory';
import type { RuleRegistryPluginConfig } from './config';
import { type IRuleDataService, RuleDataService, Dataset } from './rule_data_plugin_service';
import { AlertsClientFactory } from './alert_data_client/alerts_client_factory';
@@ -52,7 +51,6 @@ export interface RuleRegistryPluginStartDependencies {
export interface RuleRegistryPluginSetupContract {
ruleDataService: IRuleDataService;
- createLifecycleRuleTypeFactory: typeof createLifecycleRuleTypeFactory;
dataset: typeof Dataset;
}
@@ -153,7 +151,6 @@ export class RuleRegistryPlugin
return {
ruleDataService: this.ruleDataService,
- createLifecycleRuleTypeFactory,
dataset: Dataset,
};
}
diff --git a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.test.ts b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.test.ts
deleted file mode 100644
index b895c49c14a5f..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.test.ts
+++ /dev/null
@@ -1,2408 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import { loggerMock } from '@kbn/logging-mocks';
-import { pick } from 'lodash';
-import {
- ALERT_INSTANCE_ID,
- ALERT_MAINTENANCE_WINDOW_IDS,
- ALERT_RULE_CATEGORY,
- ALERT_RULE_CONSUMER,
- ALERT_RULE_NAME,
- ALERT_RULE_PRODUCER,
- ALERT_RULE_TYPE_ID,
- ALERT_RULE_UUID,
- ALERT_STATUS,
- ALERT_STATUS_ACTIVE,
- ALERT_STATUS_RECOVERED,
- ALERT_WORKFLOW_STATUS,
- ALERT_UUID,
- EVENT_ACTION,
- EVENT_KIND,
- SPACE_IDS,
- ALERT_FLAPPING,
- TAGS,
- ALERT_CONSECUTIVE_MATCHES,
-} from '../../common/technical_rule_data_field_names';
-import { createRuleDataClientMock } from '../rule_data_client/rule_data_client.mock';
-import { createLifecycleExecutor } from './create_lifecycle_executor';
-import { createDefaultAlertExecutorOptions } from './rule_executor.test_helpers';
-
-describe('createLifecycleExecutor', () => {
- it('wraps and unwraps the original executor state', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- // @ts-ignore 4.3.5 upgrade - Expression produces a union type that is too complex to represent.ts(2590)
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async (options) => {
- expect(options.state).toEqual(initialRuleState);
-
- const nextRuleState: TestRuleState = {
- aRuleStateKey: 'NEXT_RULE_STATE_VALUE',
- };
-
- return { state: nextRuleState };
- });
-
- const newExecutorResult = await executor(
- createDefaultAlertExecutorOptions({
- params: {},
- state: { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} },
- logger,
- })
- );
-
- expect(newExecutorResult.state).toEqual({
- wrapped: {
- aRuleStateKey: 'NEXT_RULE_STATE_VALUE',
- },
- trackedAlerts: {},
- trackedAlertsRecovered: {},
- });
- });
-
- it('writes initial documents for newly firing alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: { [TAGS]: ['source-tag1', 'source-tag2'] },
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: { [TAGS]: ['source-tag3', 'source-tag4'] },
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- params: {},
- state: { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert documents
- { create: { _id: expect.any(String) } },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'open',
- [EVENT_KIND]: 'signal',
- [TAGS]: ['source-tag1', 'source-tag2', 'rule-tag1', 'rule-tag2'],
- }),
- { create: { _id: expect.any(String) } },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'open',
- [EVENT_KIND]: 'signal',
- [TAGS]: ['source-tag3', 'source-tag4', 'rule-tag1', 'rule-tag2'],
- }),
- ],
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { create: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- });
-
- it('updates existing documents for repeatedly firing alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 1,
- _primary_term: 3,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert document
- {
- index: {
- _id: 'TEST_ALERT_0_UUID',
- _index: '.alerts-index-name',
- if_primary_term: 2,
- if_seq_no: 4,
- require_alias: false,
- },
- },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' },
-
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- {
- index: {
- _id: 'TEST_ALERT_1_UUID',
- _index: '.alerts-index-name',
- if_primary_term: 3,
- if_seq_no: 1,
- require_alias: false,
- },
- },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
-
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- ],
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { index: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- });
-
- it('logs warning if existing documents are in unexpected index', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: 'partial-.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 1,
- _primary_term: 3,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert document
- {
- index: {
- _id: 'TEST_ALERT_1_UUID',
- _index: '.alerts-index-name',
- if_primary_term: 3,
- if_seq_no: 1,
- require_alias: false,
- },
- },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
-
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- ],
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { index: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- expect(logger.warn).toHaveBeenCalledWith(
- `Could not update alert TEST_ALERT_0 in partial-.alerts-index-name. Partial and restored alert indices are not supported.`
- );
- });
-
- it('updates existing documents for recovered alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- [TAGS]: ['source-tag1', 'source-tag2'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- [TAGS]: ['source-tag3', 'source-tag4'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- // TEST_ALERT_0 has recovered
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' },
- [TAGS]: ['source-tag1', 'source-tag2', 'rule-tag1', 'rule-tag2'],
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [TAGS]: ['source-tag3', 'source-tag4', 'rule-tag1', 'rule-tag2'],
- }),
- ]),
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { index: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- });
-
- it('does not write alert documents when rule execution is cancelled and feature flags indicate to skip', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async (options) => {
- expect(options.state).toEqual(initialRuleState);
-
- const nextRuleState: TestRuleState = {
- aRuleStateKey: 'NEXT_RULE_STATE_VALUE',
- };
-
- return { state: nextRuleState };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- params: {},
- state: { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} },
- shouldWriteAlerts: false,
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalled();
- });
-
- it('throws error when writer initialization fails', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getWriter = jest
- .fn()
- .mockRejectedValueOnce(new Error('error initializing!'));
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async (options) => {
- const nextRuleState: TestRuleState = {
- aRuleStateKey: 'NEXT_RULE_STATE_VALUE',
- };
-
- return { state: nextRuleState };
- });
-
- await expect(() =>
- executor(
- createDefaultAlertExecutorOptions({
- params: {},
- state: { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} },
- shouldWriteAlerts: false,
- logger,
- })
- )
- ).rejects.toThrowErrorMatchingInlineSnapshot(`"error initializing!"`);
- });
-
- describe('updating flappingHistory', () => {
- it('sets flapping state to true on a new alert', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- const {
- state: { trackedAlerts, trackedAlertsRecovered },
- } = await executor(
- createDefaultAlertExecutorOptions({
- params: {},
- state: { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} },
- logger,
- })
- );
-
- const alerts = pick(trackedAlerts, [
- 'TEST_ALERT_0.flappingHistory',
- 'TEST_ALERT_1.flappingHistory',
- ]);
- expect(alerts).toMatchInlineSnapshot(`
- Object {
- "TEST_ALERT_0": Object {
- "flappingHistory": Array [
- true,
- ],
- },
- "TEST_ALERT_1": Object {
- "flappingHistory": Array [
- true,
- ],
- },
- }
- `);
- expect(trackedAlertsRecovered).toMatchInlineSnapshot(`Object {}`);
- });
-
- it('sets flapping state to false on an alert that is still active', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- const {
- state: { trackedAlerts, trackedAlertsRecovered },
- } = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- const alerts = pick(trackedAlerts, [
- 'TEST_ALERT_0.flappingHistory',
- 'TEST_ALERT_1.flappingHistory',
- ]);
- expect(alerts).toMatchInlineSnapshot(`
- Object {
- "TEST_ALERT_0": Object {
- "flappingHistory": Array [
- false,
- ],
- },
- "TEST_ALERT_1": Object {
- "flappingHistory": Array [
- false,
- ],
- },
- }
- `);
- expect(trackedAlertsRecovered).toMatchInlineSnapshot(`Object {}`);
- });
-
- it('sets flapping state to true on an alert that is active and previously recovered', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- const {
- state: { trackedAlerts, trackedAlertsRecovered },
- } = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlertsRecovered: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlerts: {},
- },
- logger,
- })
- );
-
- const alerts = pick(trackedAlerts, [
- 'TEST_ALERT_0.flappingHistory',
- 'TEST_ALERT_1.flappingHistory',
- ]);
- expect(alerts).toMatchInlineSnapshot(`
- Object {
- "TEST_ALERT_0": Object {
- "flappingHistory": Array [
- true,
- ],
- },
- "TEST_ALERT_1": Object {
- "flappingHistory": Array [
- true,
- ],
- },
- }
- `);
- expect(trackedAlertsRecovered).toMatchInlineSnapshot(`Object {}`);
- });
-
- it('sets flapping state to true on an alert that is recovered and previously active', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- // TEST_ALERT_0 has recovered
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- const {
- state: { trackedAlerts, trackedAlertsRecovered },
- } = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- const recovered = pick(trackedAlertsRecovered, ['TEST_ALERT_0.flappingHistory']);
- expect(recovered).toMatchInlineSnapshot(`
- Object {
- "TEST_ALERT_0": Object {
- "flappingHistory": Array [
- true,
- ],
- },
- }
- `);
- const active = pick(trackedAlerts, ['TEST_ALERT_1.flappingHistory']);
- expect(active).toMatchInlineSnapshot(`
- Object {
- "TEST_ALERT_1": Object {
- "flappingHistory": Array [
- false,
- ],
- },
- }
- `);
- });
-
- it('sets flapping state to false on an alert that is still recovered', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- // TEST_ALERT_0 has recovered
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- const {
- state: { trackedAlerts, trackedAlertsRecovered },
- } = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- },
- logger,
- })
- );
-
- const recovered = pick(trackedAlertsRecovered, ['TEST_ALERT_0.flappingHistory']);
- expect(recovered).toMatchInlineSnapshot(`Object {}`);
- const active = pick(trackedAlerts, ['TEST_ALERT_1.flappingHistory']);
- expect(active).toMatchInlineSnapshot(`
- Object {
- "TEST_ALERT_1": Object {
- "flappingHistory": Array [
- false,
- ],
- },
- }
- `);
- });
- });
-
- describe('set maintenance window ids on the document', () => {
- const maintenanceWindowIds = ['test-id-1', 'test-id-2'];
-
- it('updates documents with maintenance window ids for newly firing alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
-
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: { [TAGS]: ['source-tag1', 'source-tag2'] },
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: { [TAGS]: ['source-tag3', 'source-tag4'] },
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- params: {},
- state: { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert documents
- { create: { _id: expect.any(String) } },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'open',
- [EVENT_KIND]: 'signal',
- [TAGS]: ['source-tag1', 'source-tag2', 'rule-tag1', 'rule-tag2'],
- [ALERT_MAINTENANCE_WINDOW_IDS]: maintenanceWindowIds,
- }),
- { create: { _id: expect.any(String) } },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'open',
- [EVENT_KIND]: 'signal',
- [TAGS]: ['source-tag3', 'source-tag4', 'rule-tag1', 'rule-tag2'],
- [ALERT_MAINTENANCE_WINDOW_IDS]: maintenanceWindowIds,
- }),
- ],
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { index: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- });
-
- it('does not update documents with maintenance window ids for repeatedly firing alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
-
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' },
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- ],
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { index: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- });
-
- it('does not update documents with maintenance window ids for recovered alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must show up in the written doc
- [TAGS]: ['source-tag1', 'source-tag2'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' }, // this must not show up in the written doc
- [TAGS]: ['source-tag3', 'source-tag4'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- // TEST_ALERT_0 has recovered
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
-
- return { state };
- });
-
- await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- labels: { LABEL_0_KEY: 'LABEL_0_VALUE' },
- [TAGS]: ['source-tag1', 'source-tag2', 'rule-tag1', 'rule-tag2'],
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [TAGS]: ['source-tag3', 'source-tag4', 'rule-tag1', 'rule-tag2'],
- }),
- ]),
- })
- );
- expect((await ruleDataClientMock.getWriter()).bulk).not.toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // evaluation documents
- { index: {} },
- expect.objectContaining({
- [EVENT_KIND]: 'event',
- }),
- ]),
- })
- );
- });
- });
-
- describe('set flapping on the document', () => {
- const flapping = new Array(16).fill(false).concat([true, true, true, true]);
- const notFlapping = new Array(20).fill(false);
-
- it('updates documents with flapping for active alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_UUID]: 'ALERT_2_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_UUID]: 'ALERT_3_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_2',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_3',
- fields: {},
- });
-
- return { state };
- });
-
- const serializedAlerts = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: flapping,
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [false, false],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_2: {
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: flapping,
- flapping: true,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_3: {
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [false, false],
- flapping: true,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect(serializedAlerts.state.trackedAlerts).toEqual({
- TEST_ALERT_0: {
- activeCount: 1,
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- flapping: true,
- flappingHistory: flapping.slice(1).concat([false]),
- pendingRecoveredCount: 0,
- started: '2020-01-01T12:00:00.000Z',
- },
- TEST_ALERT_1: {
- activeCount: 1,
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- flapping: false,
- flappingHistory: [false, false, false],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- TEST_ALERT_2: {
- activeCount: 1,
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- flapping: true,
- flappingHistory: flapping.slice(1).concat([false]),
- pendingRecoveredCount: 0,
- started: '2020-01-01T12:00:00.000Z',
- },
- TEST_ALERT_3: {
- activeCount: 1,
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- flapping: true,
- flappingHistory: [false, false, false],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- });
-
- expect(serializedAlerts.state.trackedAlertsRecovered).toEqual({});
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_FLAPPING]: false,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: false,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_2_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: true,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_3_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: true,
- }),
- ],
- })
- );
- });
-
- it('updates existing documents for recovered alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_UUID]: 'ALERT_2_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_UUID]: 'ALERT_3_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- return { state };
- });
-
- const serializedAlerts = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [true, true, true, true],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: notFlapping,
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_2: {
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [true, true],
- flapping: true,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_3: {
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: notFlapping,
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect(serializedAlerts.state.trackedAlerts).toEqual({
- TEST_ALERT_2: {
- activeCount: 0,
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- flapping: true,
- flappingHistory: [true, true, true],
- pendingRecoveredCount: 1,
- started: '2020-01-02T12:00:00.000Z',
- },
- });
-
- expect(serializedAlerts.state.trackedAlertsRecovered).toEqual({
- TEST_ALERT_0: {
- activeCount: 0,
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- flapping: true,
- flappingHistory: [true, true, true, true, true],
- pendingRecoveredCount: 0,
- started: '2020-01-01T12:00:00.000Z',
- },
- TEST_ALERT_1: {
- activeCount: 0,
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- flapping: false,
- flappingHistory: notFlapping.slice(0, notFlapping.length - 1).concat([true]),
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- TEST_ALERT_3: {
- activeCount: 0,
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- flapping: false,
- flappingHistory: notFlapping.slice(0, notFlapping.length - 1).concat([true]),
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- });
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: false,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: false,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_2_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: true,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_3_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_FLAPPING]: false,
- }),
- ]),
- })
- );
- });
- });
-
- describe('set consecutive matches on the document', () => {
- it('updates documents with consecutive matches for active alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_UUID]: 'ALERT_2_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_UUID]: 'ALERT_3_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: 'open',
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- services.alertWithLifecycle({
- id: 'TEST_ALERT_0',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_1',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_2',
- fields: {},
- });
- services.alertWithLifecycle({
- id: 'TEST_ALERT_3',
- fields: {},
- });
-
- return { state };
- });
-
- const serializedAlerts = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_2: {
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_3: {
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect(serializedAlerts.state.trackedAlerts).toEqual({
- TEST_ALERT_0: {
- activeCount: 1,
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- flapping: false,
- flappingHistory: [false],
- pendingRecoveredCount: 0,
- started: '2020-01-01T12:00:00.000Z',
- },
- TEST_ALERT_1: {
- activeCount: 1,
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- flapping: false,
- flappingHistory: [false],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- TEST_ALERT_2: {
- activeCount: 1,
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- flapping: false,
- flappingHistory: [false],
- pendingRecoveredCount: 0,
- started: '2020-01-01T12:00:00.000Z',
- },
- TEST_ALERT_3: {
- activeCount: 1,
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- flapping: false,
- flappingHistory: [false],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- });
-
- expect(serializedAlerts.state.trackedAlertsRecovered).toEqual({});
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: [
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_WORKFLOW_STATUS]: 'closed',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [ALERT_CONSECUTIVE_MATCHES]: 1,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 1,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_2_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 1,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_3_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_WORKFLOW_STATUS]: 'open',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [EVENT_ACTION]: 'active',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 1,
- }),
- ],
- })
- );
- });
-
- it('updates existing documents for recovered alerts', async () => {
- const logger = loggerMock.create();
- const ruleDataClientMock = createRuleDataClientMock();
- ruleDataClientMock.getReader().search.mockResolvedValue({
- hits: {
- hits: [
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_UUID]: 'ALERT_0_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_UUID]: 'ALERT_1_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_UUID]: 'ALERT_2_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- {
- _source: {
- '@timestamp': '',
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_UUID]: 'ALERT_3_UUID',
- [ALERT_RULE_CATEGORY]: 'RULE_TYPE_NAME',
- [ALERT_RULE_CONSUMER]: 'CONSUMER',
- [ALERT_RULE_NAME]: 'NAME',
- [ALERT_RULE_PRODUCER]: 'PRODUCER',
- [ALERT_RULE_TYPE_ID]: 'RULE_TYPE_ID',
- [ALERT_RULE_UUID]: 'RULE_UUID',
- [ALERT_STATUS]: ALERT_STATUS_ACTIVE,
- [SPACE_IDS]: ['fake-space-id'],
- },
- _index: '.alerts-index-name',
- _seq_no: 4,
- _primary_term: 2,
- },
- ],
- },
- } as any);
- const executor = createLifecycleExecutor(
- logger,
- ruleDataClientMock
- )<{}, TestRuleState, never, never, never>(async ({ services, state }) => {
- return { state };
- });
-
- const serializedAlerts = await executor(
- createDefaultAlertExecutorOptions({
- alertId: 'TEST_ALERT_0',
- params: {},
- state: {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_1: {
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_2: {
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- TEST_ALERT_3: {
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- started: '2020-01-02T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- },
- logger,
- })
- );
-
- expect(serializedAlerts.state.trackedAlerts).toEqual({});
-
- expect(serializedAlerts.state.trackedAlertsRecovered).toEqual({
- TEST_ALERT_0: {
- activeCount: 0,
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- flapping: false,
- flappingHistory: [true],
- pendingRecoveredCount: 0,
- started: '2020-01-01T12:00:00.000Z',
- },
- TEST_ALERT_1: {
- activeCount: 0,
- alertId: 'TEST_ALERT_1',
- alertUuid: 'TEST_ALERT_1_UUID',
- flapping: false,
- flappingHistory: [true],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- TEST_ALERT_2: {
- activeCount: 0,
- alertId: 'TEST_ALERT_2',
- alertUuid: 'TEST_ALERT_2_UUID',
- flapping: false,
- flappingHistory: [true],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- TEST_ALERT_3: {
- activeCount: 0,
- alertId: 'TEST_ALERT_3',
- alertUuid: 'TEST_ALERT_3_UUID',
- flapping: false,
- flappingHistory: [true],
- pendingRecoveredCount: 0,
- started: '2020-01-02T12:00:00.000Z',
- },
- });
-
- expect((await ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledWith(
- expect.objectContaining({
- body: expect.arrayContaining([
- // alert document
- { index: expect.objectContaining({ _id: 'TEST_ALERT_0_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_0',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 0,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_1_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_1',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 0,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_2_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_2',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 0,
- }),
- { index: expect.objectContaining({ _id: 'TEST_ALERT_3_UUID' }) },
- expect.objectContaining({
- [ALERT_INSTANCE_ID]: 'TEST_ALERT_3',
- [ALERT_STATUS]: ALERT_STATUS_RECOVERED,
- [EVENT_ACTION]: 'close',
- [EVENT_KIND]: 'signal',
- [ALERT_CONSECUTIVE_MATCHES]: 0,
- }),
- ]),
- })
- );
- });
- });
-});
-
-type TestRuleState = Record & {
- aRuleStateKey: string;
-};
-
-const initialRuleState: TestRuleState = {
- aRuleStateKey: 'INITIAL_RULE_STATE_VALUE',
-};
diff --git a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts
deleted file mode 100644
index cdbdf56fabc51..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts
+++ /dev/null
@@ -1,479 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import type { Logger } from '@kbn/logging';
-import type { PublicContract } from '@kbn/utility-types';
-import { getOrElse } from 'fp-ts/lib/Either';
-import { v4 } from 'uuid';
-import { difference } from 'lodash';
-import {
- RuleExecutorOptions,
- Alert,
- AlertInstanceContext,
- AlertInstanceState,
- RuleTypeParams,
- RuleTypeState,
- isValidAlertIndexName,
-} from '@kbn/alerting-plugin/server';
-import { isFlapping } from '@kbn/alerting-plugin/server/lib';
-import { wrappedStateRt, WrappedLifecycleRuleState } from '@kbn/alerting-state-types';
-export type {
- TrackedLifecycleAlertState,
- WrappedLifecycleRuleState,
-} from '@kbn/alerting-state-types';
-import { ParsedExperimentalFields } from '../../common/parse_experimental_fields';
-import { ParsedTechnicalFields } from '../../common/parse_technical_fields';
-import {
- ALERT_TIME_RANGE,
- ALERT_DURATION,
- ALERT_END,
- ALERT_INSTANCE_ID,
- ALERT_START,
- ALERT_STATUS,
- ALERT_STATUS_ACTIVE,
- ALERT_STATUS_RECOVERED,
- ALERT_UUID,
- ALERT_WORKFLOW_STATUS,
- EVENT_ACTION,
- EVENT_KIND,
- TAGS,
- TIMESTAMP,
- VERSION,
- ALERT_FLAPPING,
- ALERT_MAINTENANCE_WINDOW_IDS,
-} from '../../common/technical_rule_data_field_names';
-import { CommonAlertFieldNameLatest, CommonAlertIdFieldNameLatest } from '../../common/schemas';
-import { IRuleDataClient } from '../rule_data_client';
-import { AlertExecutorOptionsWithExtraServices } from '../types';
-import { fetchExistingAlerts } from './fetch_existing_alerts';
-import { getCommonAlertFields } from './get_common_alert_fields';
-import { getUpdatedFlappingHistory } from './get_updated_flapping_history';
-import { fetchAlertByAlertUUID } from './fetch_alert_by_uuid';
-import { getAlertsForNotification } from './get_alerts_for_notification';
-
-type ImplicitTechnicalFieldName = CommonAlertFieldNameLatest | CommonAlertIdFieldNameLatest;
-
-type ExplicitTechnicalAlertFields = Partial<
- Omit
->;
-
-type ExplicitAlertFields = Record & // every field can have values of arbitrary types
- ExplicitTechnicalAlertFields; // but technical fields must obey their respective type
-
-export type LifecycleAlertService<
- InstanceState extends AlertInstanceState = never,
- InstanceContext extends AlertInstanceContext = never,
- ActionGroupIds extends string = never
-> = (alert: {
- id: string;
- fields: ExplicitAlertFields;
-}) => Alert;
-
-export interface LifecycleAlertServices<
- InstanceState extends AlertInstanceState = never,
- InstanceContext extends AlertInstanceContext = never,
- ActionGroupIds extends string = never
-> {
- alertWithLifecycle: LifecycleAlertService;
- getAlertStartedDate: (alertInstanceId: string) => string | null;
- getAlertUuid: (alertInstanceId: string) => string;
- getAlertByAlertUuid: (
- alertUuid: string
- ) => Promise | null> | null;
-}
-
-export type LifecycleRuleExecutor<
- Params extends RuleTypeParams = never,
- State extends RuleTypeState = never,
- InstanceState extends AlertInstanceState = never,
- InstanceContext extends AlertInstanceContext = never,
- ActionGroupIds extends string = never
-> = (
- options: AlertExecutorOptionsWithExtraServices<
- Params,
- State,
- InstanceState,
- InstanceContext,
- ActionGroupIds,
- LifecycleAlertServices
- >
-) => Promise<{ state: State }>;
-
-export const createLifecycleExecutor =
- (logger: Logger, ruleDataClient: PublicContract) =>
- <
- Params extends RuleTypeParams = never,
- State extends RuleTypeState = never,
- InstanceState extends AlertInstanceState = never,
- InstanceContext extends AlertInstanceContext = never,
- ActionGroupIds extends string = never
- >(
- wrappedExecutor: LifecycleRuleExecutor<
- Params,
- State,
- InstanceState,
- InstanceContext,
- ActionGroupIds
- >
- ) =>
- async (
- options: RuleExecutorOptions<
- Params,
- WrappedLifecycleRuleState,
- InstanceState,
- InstanceContext,
- ActionGroupIds
- >
- ): Promise<{ state: WrappedLifecycleRuleState }> => {
- const {
- services: { alertFactory, getMaintenanceWindowIds, shouldWriteAlerts },
- state: previousState,
- flappingSettings,
- rule,
- } = options;
-
- const ruleDataClientWriter = await ruleDataClient.getWriter();
-
- const state = getOrElse(
- (): WrappedLifecycleRuleState => ({
- wrapped: previousState as State,
- trackedAlerts: {},
- trackedAlertsRecovered: {},
- })
- )(wrappedStateRt().decode(previousState));
-
- const commonRuleFields = getCommonAlertFields(options);
-
- const currentAlerts: Record = {};
- const alertUuidMap: Map = new Map();
-
- const lifecycleAlertServices: LifecycleAlertServices<
- InstanceState,
- InstanceContext,
- ActionGroupIds
- > = {
- alertWithLifecycle: ({ id, fields }) => {
- currentAlerts[id] = fields;
- const alert = alertFactory.create(id);
- const uuid = alert.getUuid();
- alertUuidMap.set(id, uuid);
- return alert;
- },
- getAlertStartedDate: (alertId: string) => state.trackedAlerts[alertId]?.started ?? null,
- getAlertUuid: (alertId: string) => {
- const uuid = alertUuidMap.get(alertId);
- if (uuid) {
- return uuid;
- }
-
- const trackedAlert = state.trackedAlerts[alertId];
- if (trackedAlert) {
- return trackedAlert.alertUuid;
- }
-
- const trackedRecoveredAlert = state.trackedAlertsRecovered[alertId];
- if (trackedRecoveredAlert) {
- return trackedRecoveredAlert.alertUuid;
- }
-
- const alertInfo = `alert ${alertId} of rule ${rule.ruleTypeId}:${rule.id}`;
- logger.warn(
- `[Rule Registry] requesting uuid for ${alertInfo} which is not tracked, generating dynamically`
- );
- return v4();
- },
- getAlertByAlertUuid: async (alertUuid: string) => {
- try {
- return await fetchAlertByAlertUUID(ruleDataClient, alertUuid);
- } catch (err) {
- return null;
- }
- },
- };
-
- const wrappedExecutorResult = await wrappedExecutor({
- ...options,
- state: state.wrapped != null ? state.wrapped : ({} as State),
- services: {
- ...options.services,
- ...lifecycleAlertServices,
- },
- });
-
- const currentAlertIds = Object.keys(currentAlerts);
- const trackedAlertIds = Object.keys(state.trackedAlerts);
- const trackedAlertRecoveredIds = Object.keys(state.trackedAlertsRecovered);
- const newAlertIds = difference(currentAlertIds, trackedAlertIds);
- const allAlertIds = [...new Set(currentAlertIds.concat(trackedAlertIds))];
-
- const trackedAlertStates = Object.values(state.trackedAlerts);
-
- logger.debug(
- `[Rule Registry] Tracking ${allAlertIds.length} alerts (${newAlertIds.length} new, ${trackedAlertStates.length} previous)`
- );
-
- // load maintenance window ids if there are new alerts
- const maintenanceWindowIds: string[] = allAlertIds.length
- ? await getMaintenanceWindowIds()
- : [];
-
- interface TrackedAlertData {
- indexName: string;
- fields: Partial;
- seqNo: number | undefined;
- primaryTerm: number | undefined;
- }
-
- const trackedAlertsDataMap: Record = {};
-
- if (trackedAlertStates.length) {
- const result = await fetchExistingAlerts(
- ruleDataClient,
- trackedAlertStates,
- commonRuleFields
- );
- result.forEach((hit) => {
- const alertInstanceId = hit._source ? hit._source[ALERT_INSTANCE_ID] : void 0;
- if (alertInstanceId && hit._source) {
- const alertLabel = `${rule.ruleTypeId}:${rule.id} ${alertInstanceId}`;
- if (hit._seq_no == null) {
- logger.error(`missing _seq_no on alert instance ${alertLabel}`);
- } else if (hit._primary_term == null) {
- logger.error(`missing _primary_term on alert instance ${alertLabel}`);
- } else {
- trackedAlertsDataMap[alertInstanceId] = {
- indexName: hit._index,
- fields: hit._source,
- seqNo: hit._seq_no,
- primaryTerm: hit._primary_term,
- };
- }
- }
- });
- }
-
- const makeEventsDataMapFor = (alertIds: string[]) =>
- alertIds
- .filter((alertId) => {
- const alertData = trackedAlertsDataMap[alertId];
- const alertIndex = alertData?.indexName;
- if (!alertIndex) {
- return true;
- } else if (!isValidAlertIndexName(alertIndex)) {
- logger.warn(
- `Could not update alert ${alertId} in ${alertIndex}. Partial and restored alert indices are not supported.`
- );
- return false;
- }
- return true;
- })
- .map((alertId) => {
- const alertData = trackedAlertsDataMap[alertId];
- const currentAlertData = currentAlerts[alertId];
- const trackedAlert = state.trackedAlerts[alertId];
-
- if (!alertData) {
- logger.debug(`[Rule Registry] Could not find alert data for ${alertId}`);
- }
-
- const isNew = !trackedAlert;
- const isRecovered = !currentAlertData;
- const isActive = !isRecovered;
-
- const flappingHistory = getUpdatedFlappingHistory(
- flappingSettings,
- alertId,
- state,
- isNew,
- isRecovered,
- isActive,
- trackedAlertRecoveredIds
- );
-
- const { alertUuid, started, flapping, pendingRecoveredCount, activeCount } = !isNew
- ? state.trackedAlerts[alertId]
- : {
- alertUuid: lifecycleAlertServices.getAlertUuid(alertId),
- started: commonRuleFields[TIMESTAMP],
- flapping: state.trackedAlertsRecovered[alertId]
- ? state.trackedAlertsRecovered[alertId].flapping
- : false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- };
-
- const event: ParsedTechnicalFields & ParsedExperimentalFields = {
- ...alertData?.fields,
- ...commonRuleFields,
- ...currentAlertData,
- [ALERT_DURATION]: (options.startedAt.getTime() - new Date(started).getTime()) * 1000,
- [ALERT_TIME_RANGE]: isRecovered
- ? {
- gte: started,
- lte: commonRuleFields[TIMESTAMP],
- }
- : { gte: started },
- [ALERT_INSTANCE_ID]: alertId,
- [ALERT_START]: started,
- [ALERT_UUID]: alertUuid,
- [ALERT_STATUS]: isRecovered ? ALERT_STATUS_RECOVERED : ALERT_STATUS_ACTIVE,
- [ALERT_WORKFLOW_STATUS]: alertData?.fields[ALERT_WORKFLOW_STATUS] ?? 'open',
- [EVENT_KIND]: 'signal',
- [EVENT_ACTION]: isNew ? 'open' : isActive ? 'active' : 'close',
- [TAGS]: Array.from(
- new Set([
- ...(currentAlertData?.tags ?? []),
- ...(alertData?.fields[TAGS] ?? []),
- ...(options.rule.tags ?? []),
- ])
- ),
- [VERSION]: ruleDataClient.kibanaVersion,
- [ALERT_FLAPPING]: flapping,
- ...(isRecovered ? { [ALERT_END]: commonRuleFields[TIMESTAMP] } : {}),
- ...(isNew && maintenanceWindowIds?.length
- ? { [ALERT_MAINTENANCE_WINDOW_IDS]: maintenanceWindowIds }
- : {}),
- };
-
- return {
- indexName: alertData?.indexName,
- seqNo: alertData?.seqNo,
- primaryTerm: alertData?.primaryTerm,
- event,
- flappingHistory,
- flapping,
- pendingRecoveredCount,
- activeCount,
- };
- });
-
- const trackedEventsToIndex = makeEventsDataMapFor(trackedAlertIds);
- const newEventsToIndex = makeEventsDataMapFor(newAlertIds);
- const trackedRecoveredEventsToIndex = makeEventsDataMapFor(trackedAlertRecoveredIds);
- const allEventsToIndex = getAlertsForNotification(
- flappingSettings,
- rule.alertDelay?.active ?? 0,
- trackedEventsToIndex,
- newEventsToIndex,
- { maintenanceWindowIds, timestamp: commonRuleFields[TIMESTAMP] }
- );
-
- // Only write alerts if:
- // - writing is enabled
- // AND
- // - rule execution has not been cancelled due to timeout
- // OR
- // - if execution has been cancelled due to timeout, if feature flags are configured to write alerts anyway
- const writeAlerts = ruleDataClient.isWriteEnabled() && shouldWriteAlerts();
-
- if (allEventsToIndex.length > 0 && writeAlerts) {
- logger.debug(`[Rule Registry] Preparing to index ${allEventsToIndex.length} alerts.`);
-
- await ruleDataClientWriter.bulk({
- body: allEventsToIndex.flatMap(({ event, indexName, seqNo, primaryTerm }) => [
- indexName
- ? {
- index: {
- _id: event[ALERT_UUID]!,
- _index: indexName,
- if_seq_no: seqNo,
- if_primary_term: primaryTerm,
- require_alias: false,
- },
- }
- : {
- create: {
- _id: event[ALERT_UUID]!,
- },
- },
- event,
- ]),
- refresh: true,
- });
- } else {
- logger.debug(
- `[Rule Registry] Not indexing ${allEventsToIndex.length} alerts because writing has been disabled.`
- );
- }
-
- const nextTrackedAlerts = Object.fromEntries(
- [...newEventsToIndex, ...trackedEventsToIndex]
- .filter(({ event }) => event[ALERT_STATUS] !== ALERT_STATUS_RECOVERED)
- .map(
- ({
- event,
- flappingHistory,
- flapping: isCurrentlyFlapping,
- pendingRecoveredCount,
- activeCount,
- }) => {
- const alertId = event[ALERT_INSTANCE_ID]!;
- const alertUuid = event[ALERT_UUID]!;
- const started = new Date(event[ALERT_START]!).toISOString();
- const flapping = isFlapping(flappingSettings, flappingHistory, isCurrentlyFlapping);
- return [
- alertId,
- {
- alertId,
- alertUuid,
- started,
- flappingHistory,
- flapping,
- pendingRecoveredCount,
- activeCount,
- },
- ];
- }
- )
- );
-
- const nextTrackedAlertsRecovered = Object.fromEntries(
- [...allEventsToIndex, ...trackedRecoveredEventsToIndex]
- .filter(
- ({ event, flappingHistory, flapping }) =>
- // return recovered alerts if they are flapping or if the flapping array is not at capacity
- // this is a space saving effort that will stop tracking a recovered alert if it wasn't flapping and doesn't have state changes
- // in the last max capcity number of executions
- event[ALERT_STATUS] === ALERT_STATUS_RECOVERED &&
- (flapping || flappingHistory.filter((f: boolean) => f).length > 0)
- )
- .map(
- ({
- event,
- flappingHistory,
- flapping: isCurrentlyFlapping,
- pendingRecoveredCount,
- activeCount,
- }) => {
- const alertId = event[ALERT_INSTANCE_ID]!;
- const alertUuid = event[ALERT_UUID]!;
- const started = new Date(event[ALERT_START]!).toISOString();
- const flapping = isFlapping(flappingSettings, flappingHistory, isCurrentlyFlapping);
- return [
- alertId,
- {
- alertId,
- alertUuid,
- started,
- flappingHistory,
- flapping,
- pendingRecoveredCount,
- activeCount,
- },
- ];
- }
- )
- );
-
- return {
- state: {
- wrapped: wrappedExecutorResult?.state ?? ({} as State),
- trackedAlerts: writeAlerts ? nextTrackedAlerts : {},
- trackedAlertsRecovered: writeAlerts ? nextTrackedAlertsRecovered : {},
- },
- };
- };
diff --git a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_executor_mock.ts b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_executor_mock.ts
deleted file mode 100644
index bf0d98d5156af..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_executor_mock.ts
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import {
- RuleTypeParams,
- RuleTypeState,
- AlertInstanceState,
- AlertInstanceContext,
-} from '@kbn/alerting-plugin/server';
-import { AlertExecutorOptionsWithExtraServices } from '../types';
-
-import { LifecycleAlertServices, LifecycleRuleExecutor } from './create_lifecycle_executor';
-
-export const createLifecycleRuleExecutorMock =
- <
- Params extends RuleTypeParams = never,
- State extends RuleTypeState = never,
- InstanceState extends AlertInstanceState = never,
- InstanceContext extends AlertInstanceContext = never,
- ActionGroupIds extends string = never
- >(
- executor: LifecycleRuleExecutor
- ) =>
- async (
- options: AlertExecutorOptionsWithExtraServices<
- Params,
- State,
- InstanceState,
- InstanceContext,
- ActionGroupIds,
- LifecycleAlertServices
- >
- ) =>
- await executor(options);
diff --git a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type.test.ts b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type.test.ts
deleted file mode 100644
index 6dbc33b666497..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type.test.ts
+++ /dev/null
@@ -1,512 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import { schema } from '@kbn/config-schema';
-import {
- ALERT_DURATION,
- ALERT_STATUS,
- ALERT_STATUS_ACTIVE,
- ALERT_STATUS_RECOVERED,
- ALERT_UUID,
- ALERT_TIME_RANGE,
-} from '@kbn/rule-data-utils';
-import { loggerMock } from '@kbn/logging-mocks';
-import { castArray, omit } from 'lodash';
-import { createRuleDataClientMock } from '../rule_data_client/rule_data_client.mock';
-import { createLifecycleRuleTypeFactory } from './create_lifecycle_rule_type_factory';
-import { ISearchStartSearchSource } from '@kbn/data-plugin/common';
-import { SharePluginStart } from '@kbn/share-plugin/server';
-import { dataViewPluginMocks } from '@kbn/data-views-plugin/public/mocks';
-import { DEFAULT_FLAPPING_SETTINGS } from '@kbn/alerting-plugin/common/rules_settings';
-
-type RuleTestHelpers = ReturnType;
-
-function createRule(shouldWriteAlerts: boolean = true) {
- const ruleDataClientMock = createRuleDataClientMock();
-
- const factory = createLifecycleRuleTypeFactory({
- ruleDataClient: ruleDataClientMock,
- logger: loggerMock.create(),
- });
-
- let nextAlerts: Array<{ id: string; fields: Record }> = [];
-
- const type = factory({
- actionGroups: [
- {
- id: 'warning',
- name: 'warning',
- },
- ],
- actionVariables: {
- context: [],
- params: [],
- state: [],
- },
- defaultActionGroupId: 'warning',
- executor: async ({ services }) => {
- nextAlerts.forEach((alert) => {
- services.alertWithLifecycle(alert);
- });
- nextAlerts = [];
- return { state: {} };
- },
- id: 'ruleTypeId',
- isExportable: true,
- minimumLicenseRequired: 'basic',
- name: 'ruleTypeName',
- category: 'test',
- producer: 'producer',
- validate: {
- params: schema.object(
- {},
- {
- unknowns: 'allow',
- }
- ),
- },
- });
-
- let state: Record = {};
- let previousStartedAt: Date | null;
- const createdAt = new Date('2021-06-16T09:00:00.000Z');
-
- const scheduleActions = jest.fn();
-
- let uuidCounter = 1;
- const getUuid = jest.fn(() => `uuid-${uuidCounter++}`);
-
- const alertFactory = {
- create: () => {
- return {
- scheduleActions,
- getUuid,
- } as any;
- },
- alertLimit: {
- getValue: () => 1000,
- setLimitReached: () => {},
- },
- done: () => ({ getRecoveredAlerts: () => [] }),
- };
-
- return {
- alertWithLifecycle: async (alerts: Array<{ id: string; fields: Record }>) => {
- nextAlerts = alerts;
-
- const startedAt = new Date((previousStartedAt ?? createdAt).getTime() + 60000);
-
- scheduleActions.mockClear();
-
- ({ state } = ((await type.executor({
- executionId: 'b33f65d7-6e8b-4aae-8d20-c93613dec9f9',
- logger: loggerMock.create(),
- namespace: 'namespace',
- params: { threshold: 1, operator: '>' },
- previousStartedAt,
- rule: {
- id: 'alertId',
- actions: [],
- consumer: 'consumer',
- createdAt,
- createdBy: 'createdBy',
- enabled: true,
- muteAll: false,
- name: 'name',
- notifyWhen: 'onActionGroupChange',
- producer: 'producer',
- revision: 0,
- ruleTypeId: 'ruleTypeId',
- ruleTypeName: 'ruleTypeName',
- schedule: {
- interval: '1m',
- },
- snoozeSchedule: [],
- tags: ['tags'],
- throttle: null,
- updatedAt: createdAt,
- updatedBy: 'updatedBy',
- },
- services: {
- alertsClient: null,
- alertFactory,
- savedObjectsClient: {} as any,
- scopedClusterClient: {} as any,
- search: {} as any,
- getMaintenanceWindowIds: async () => [],
- getSearchSourceClient: async () => ({} as ISearchStartSearchSource),
- shouldStopExecution: () => false,
- shouldWriteAlerts: () => shouldWriteAlerts,
- uiSettingsClient: {} as any,
- share: {} as SharePluginStart,
- getDataViews: async () => dataViewPluginMocks.createStartContract(),
- },
- spaceId: 'spaceId',
- startedAt,
- startedAtOverridden: false,
- state,
- flappingSettings: DEFAULT_FLAPPING_SETTINGS,
- getTimeRange: () => {
- const date = new Date(Date.now()).toISOString();
- return { dateStart: date, dateEnd: date };
- },
- })) ?? {}) as Record);
-
- previousStartedAt = startedAt;
- },
- scheduleActions,
- ruleDataClientMock,
- };
-}
-
-describe('createLifecycleRuleTypeFactory', () => {
- describe('with a new rule', () => {
- let helpers: RuleTestHelpers;
-
- beforeEach(() => {
- helpers = createRule();
- });
-
- describe('when writing is disabled', () => {
- beforeEach(() => {
- helpers.ruleDataClientMock.isWriteEnabled.mockReturnValue(false);
- });
-
- it("doesn't persist anything", async () => {
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- ]);
-
- expect((await helpers.ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledTimes(0);
- });
- });
-
- describe('when rule is cancelled due to timeout and config flags indicate to skip actions', () => {
- beforeEach(() => {
- helpers = createRule(false);
- helpers.ruleDataClientMock.isWriteEnabled.mockReturnValue(true);
- });
-
- it("doesn't persist anything", async () => {
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- ]);
-
- expect((await helpers.ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledTimes(0);
- });
- });
-
- describe('when alerts are new', () => {
- beforeEach(async () => {
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- {
- id: 'opbeans-node',
- fields: {
- 'service.name': 'opbeans-node',
- },
- },
- ]);
- });
-
- it('writes the correct alerts', async () => {
- expect((await helpers.ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledTimes(1);
-
- const body = (await helpers.ruleDataClientMock.getWriter()).bulk.mock.calls[0][0].body!;
-
- const documents: any[] = body.filter((op: any) => !isOpDoc(op));
-
- const evaluationDocuments = documents.filter((doc) => doc['event.kind'] === 'event');
- const alertDocuments = documents.filter((doc) => doc['event.kind'] === 'signal');
-
- expect(evaluationDocuments.length).toBe(0);
- expect(alertDocuments.length).toBe(2);
-
- expect(
- alertDocuments.every((doc) => doc[ALERT_STATUS] === ALERT_STATUS_ACTIVE)
- ).toBeTruthy();
-
- expect(alertDocuments.every((doc) => doc[ALERT_DURATION] === 0)).toBeTruthy();
-
- expect(alertDocuments.every((doc) => doc['event.action'] === 'open')).toBeTruthy();
-
- expect(documents.map((doc) => omit(doc, ALERT_UUID))).toMatchInlineSnapshot(`
- Array [
- Object {
- "@timestamp": "2021-06-16T09:01:00.000Z",
- "event.action": "open",
- "event.kind": "signal",
- "kibana.alert.consecutive_matches": 1,
- "kibana.alert.duration.us": 0,
- "kibana.alert.flapping": false,
- "kibana.alert.instance.id": "opbeans-java",
- "kibana.alert.rule.category": "ruleTypeName",
- "kibana.alert.rule.consumer": "consumer",
- "kibana.alert.rule.execution.uuid": "b33f65d7-6e8b-4aae-8d20-c93613dec9f9",
- "kibana.alert.rule.name": "name",
- "kibana.alert.rule.parameters": Object {
- "operator": ">",
- "threshold": 1,
- },
- "kibana.alert.rule.producer": "producer",
- "kibana.alert.rule.revision": 0,
- "kibana.alert.rule.rule_type_id": "ruleTypeId",
- "kibana.alert.rule.tags": Array [
- "tags",
- ],
- "kibana.alert.rule.uuid": "alertId",
- "kibana.alert.start": "2021-06-16T09:01:00.000Z",
- "kibana.alert.status": "active",
- "kibana.alert.time_range": Object {
- "gte": "2021-06-16T09:01:00.000Z",
- },
- "kibana.alert.workflow_status": "open",
- "kibana.space_ids": Array [
- "spaceId",
- ],
- "kibana.version": "7.16.0",
- "service.name": "opbeans-java",
- "tags": Array [
- "tags",
- ],
- },
- Object {
- "@timestamp": "2021-06-16T09:01:00.000Z",
- "event.action": "open",
- "event.kind": "signal",
- "kibana.alert.consecutive_matches": 1,
- "kibana.alert.duration.us": 0,
- "kibana.alert.flapping": false,
- "kibana.alert.instance.id": "opbeans-node",
- "kibana.alert.rule.category": "ruleTypeName",
- "kibana.alert.rule.consumer": "consumer",
- "kibana.alert.rule.execution.uuid": "b33f65d7-6e8b-4aae-8d20-c93613dec9f9",
- "kibana.alert.rule.name": "name",
- "kibana.alert.rule.parameters": Object {
- "operator": ">",
- "threshold": 1,
- },
- "kibana.alert.rule.producer": "producer",
- "kibana.alert.rule.revision": 0,
- "kibana.alert.rule.rule_type_id": "ruleTypeId",
- "kibana.alert.rule.tags": Array [
- "tags",
- ],
- "kibana.alert.rule.uuid": "alertId",
- "kibana.alert.start": "2021-06-16T09:01:00.000Z",
- "kibana.alert.status": "active",
- "kibana.alert.time_range": Object {
- "gte": "2021-06-16T09:01:00.000Z",
- },
- "kibana.alert.workflow_status": "open",
- "kibana.space_ids": Array [
- "spaceId",
- ],
- "kibana.version": "7.16.0",
- "service.name": "opbeans-node",
- "tags": Array [
- "tags",
- ],
- },
- ]
- `);
- });
- });
-
- describe('when alerts are active', () => {
- beforeEach(async () => {
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- {
- id: 'opbeans-node',
- fields: {
- 'service.name': 'opbeans-node',
- },
- },
- ]);
-
- // TODO mock the resolved value before calling alertWithLifecycle again
- const lastOpbeansNodeDoc = (
- await helpers.ruleDataClientMock.getWriter()
- ).bulk.mock.calls[0][0].body
- ?.concat()
- .reverse()
- .find((doc: any) => !isOpDoc(doc) && doc['service.name'] === 'opbeans-node') as Record<
- string,
- any
- >;
-
- // @ts-ignore 4.3.5 upgrade
- helpers.ruleDataClientMock.getReader().search.mockResolvedValueOnce({
- hits: {
- hits: [{ _source: lastOpbeansNodeDoc } as any],
- total: {
- value: 1,
- relation: 'eq',
- },
- },
- took: 0,
- timed_out: false,
- _shards: {
- failed: 0,
- successful: 1,
- total: 1,
- },
- });
-
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- {
- id: 'opbeans-node',
- fields: {
- 'service.name': 'opbeans-node',
- 'kibana.alert.workflow_status': 'closed',
- },
- },
- ]);
- });
-
- it('writes the correct alerts', async () => {
- expect((await helpers.ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledTimes(2);
- const body = (await helpers.ruleDataClientMock.getWriter()).bulk.mock.calls[1][0].body!;
-
- const documents: any[] = body.filter((op: any) => !isOpDoc(op));
-
- const evaluationDocuments = documents.filter((doc) => doc['event.kind'] === 'event');
- const alertDocuments = documents.filter((doc) => doc['event.kind'] === 'signal');
-
- expect(evaluationDocuments.length).toBe(0);
- expect(alertDocuments.length).toBe(2);
-
- expect(
- alertDocuments.every((doc) => doc[ALERT_STATUS] === ALERT_STATUS_ACTIVE)
- ).toBeTruthy();
- expect(alertDocuments.every((doc) => doc['event.action'] === 'active')).toBeTruthy();
-
- expect(alertDocuments.every((doc) => doc[ALERT_DURATION] > 0)).toBeTruthy();
- });
- });
-
- describe('when alerts recover', () => {
- beforeEach(async () => {
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- {
- id: 'opbeans-node',
- fields: {
- 'service.name': 'opbeans-node',
- },
- },
- ]);
-
- const lastOpbeansNodeDoc = (
- await helpers.ruleDataClientMock.getWriter()
- ).bulk.mock.calls[0][0].body
- ?.concat()
- .reverse()
- .find((doc: any) => !isOpDoc(doc) && doc['service.name'] === 'opbeans-node') as Record<
- string,
- any
- >;
-
- helpers.ruleDataClientMock.getReader().search.mockResolvedValueOnce({
- hits: {
- hits: [
- {
- _source: lastOpbeansNodeDoc,
- _index: '.alerts-a',
- _primary_term: 4,
- _seq_no: 2,
- } as any,
- ],
- total: {
- value: 1,
- relation: 'eq',
- },
- },
- took: 0,
- timed_out: false,
- _shards: {
- failed: 0,
- successful: 1,
- total: 1,
- },
- });
-
- await helpers.alertWithLifecycle([
- {
- id: 'opbeans-java',
- fields: {
- 'service.name': 'opbeans-java',
- },
- },
- ]);
- });
-
- it('writes the correct alerts', async () => {
- expect((await helpers.ruleDataClientMock.getWriter()).bulk).toHaveBeenCalledTimes(2);
-
- const body = (await helpers.ruleDataClientMock.getWriter()).bulk.mock.calls[1][0].body!;
-
- const documents: any[] = body.filter((op: any) => !isOpDoc(op));
-
- const opbeansJavaAlertDoc = documents.find(
- (doc) => castArray(doc['service.name'])[0] === 'opbeans-java'
- );
- const opbeansNodeAlertDoc = documents.find(
- (doc) => castArray(doc['service.name'])[0] === 'opbeans-node'
- );
-
- expect(opbeansJavaAlertDoc['event.action']).toBe('active');
- expect(opbeansJavaAlertDoc[ALERT_STATUS]).toBe(ALERT_STATUS_ACTIVE);
-
- expect(opbeansNodeAlertDoc['event.action']).toBe('close');
- expect(opbeansNodeAlertDoc[ALERT_STATUS]).toBe(ALERT_STATUS_RECOVERED);
- expect(opbeansNodeAlertDoc[ALERT_TIME_RANGE]).toEqual({
- gte: '2021-06-16T09:01:00.000Z',
- lte: '2021-06-16T09:02:00.000Z',
- });
- });
- });
- });
-});
-
-function isOpDoc(doc: any) {
- if (doc?.index?._id) return true;
- if (doc?.create?._id) return true;
- return false;
-}
diff --git a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts
deleted file mode 100644
index 7f1be5ff54f83..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_rule_type_factory.ts
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-import { Logger } from '@kbn/logging';
-import {
- AlertInstanceContext,
- AlertInstanceState,
- RuleTypeParams,
- RuleTypeState,
-} from '@kbn/alerting-plugin/common';
-import { IRuleDataClient } from '../rule_data_client';
-import { AlertTypeWithExecutor } from '../types';
-import { createLifecycleExecutor, LifecycleAlertServices } from './create_lifecycle_executor';
-
-export const createLifecycleRuleTypeFactory =
- ({ logger, ruleDataClient }: { logger: Logger; ruleDataClient: IRuleDataClient }) =>
- <
- TParams extends RuleTypeParams,
- TAlertInstanceState extends AlertInstanceState,
- TAlertInstanceContext extends AlertInstanceContext,
- TActionGroupIds extends string,
- TServices extends LifecycleAlertServices<
- TAlertInstanceState,
- TAlertInstanceContext,
- TActionGroupIds
- >
- >(
- type: AlertTypeWithExecutor
- ): AlertTypeWithExecutor => {
- const createBoundLifecycleExecutor = createLifecycleExecutor(logger, ruleDataClient);
- const executor = createBoundLifecycleExecutor<
- TParams,
- RuleTypeState,
- AlertInstanceState,
- TAlertInstanceContext,
- string
- >(type.executor as any);
- return {
- ...type,
- executor: executor as any,
- };
- };
diff --git a/x-pack/plugins/rule_registry/server/utils/get_updated_flapping_history.test.ts b/x-pack/plugins/rule_registry/server/utils/get_updated_flapping_history.test.ts
deleted file mode 100644
index 84685779186d9..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/get_updated_flapping_history.test.ts
+++ /dev/null
@@ -1,207 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import {
- DEFAULT_FLAPPING_SETTINGS,
- DISABLE_FLAPPING_SETTINGS,
-} from '@kbn/alerting-plugin/common/rules_settings';
-import { getUpdatedFlappingHistory } from './get_updated_flapping_history';
-
-describe('getUpdatedFlappingHistory', () => {
- type TestRuleState = Record & {
- aRuleStateKey: string;
- };
- const initialRuleState: TestRuleState = {
- aRuleStateKey: 'INITIAL_RULE_STATE_VALUE',
- };
-
- test('sets flapping state to true if the alert is new', () => {
- const state = { wrapped: initialRuleState, trackedAlerts: {}, trackedAlertsRecovered: {} };
- expect(
- getUpdatedFlappingHistory(
- DEFAULT_FLAPPING_SETTINGS,
- 'TEST_ALERT_0',
- state,
- true,
- false,
- false,
- []
- )
- ).toMatchInlineSnapshot(`
- Array [
- true,
- ]
- `);
- });
-
- test('sets flapping state to false on an alert that is still active', () => {
- const state = {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- };
- expect(
- getUpdatedFlappingHistory(
- DEFAULT_FLAPPING_SETTINGS,
- 'TEST_ALERT_0',
- state,
- false,
- false,
- true,
- []
- )
- ).toMatchInlineSnapshot(`
- Array [
- false,
- ]
- `);
- });
-
- test('sets flapping state to true on an alert that is active and previously recovered', () => {
- const state = {
- wrapped: initialRuleState,
- trackedAlertsRecovered: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlerts: {},
- };
- const recoveredIds = ['TEST_ALERT_0'];
- expect(
- getUpdatedFlappingHistory(
- DEFAULT_FLAPPING_SETTINGS,
- 'TEST_ALERT_0',
- state,
- true,
- false,
- true,
- recoveredIds
- )
- ).toMatchInlineSnapshot(`
- Array [
- true,
- ]
- `);
- expect(recoveredIds).toEqual([]);
- });
-
- test('sets flapping state to true on an alert that is recovered and previously active', () => {
- const state = {
- wrapped: initialRuleState,
- trackedAlerts: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- trackedAlertsRecovered: {},
- };
- const recoveredIds = ['TEST_ALERT_0'];
- expect(
- getUpdatedFlappingHistory(
- DEFAULT_FLAPPING_SETTINGS,
- 'TEST_ALERT_0',
- state,
- false,
- true,
- false,
- recoveredIds
- )
- ).toMatchInlineSnapshot(`
- Array [
- true,
- ]
- `);
- expect(recoveredIds).toEqual(['TEST_ALERT_0']);
- });
-
- test('sets flapping state to false on an alert that is still recovered', () => {
- const state = {
- wrapped: initialRuleState,
- trackedAlerts: {},
- trackedAlertsRecovered: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- };
- const recoveredIds = ['TEST_ALERT_0'];
- expect(
- getUpdatedFlappingHistory(
- DEFAULT_FLAPPING_SETTINGS,
- 'TEST_ALERT_0',
- state,
- false,
- true,
- false,
- recoveredIds
- )
- ).toMatchInlineSnapshot(`
- Array [
- false,
- ]
- `);
- expect(recoveredIds).toEqual(['TEST_ALERT_0']);
- });
-
- test('does not set flapping state if flapping is not enabled', () => {
- const state = {
- wrapped: initialRuleState,
- trackedAlerts: {},
- trackedAlertsRecovered: {
- TEST_ALERT_0: {
- alertId: 'TEST_ALERT_0',
- alertUuid: 'TEST_ALERT_0_UUID',
- started: '2020-01-01T12:00:00.000Z',
- flappingHistory: [],
- flapping: false,
- pendingRecoveredCount: 0,
- activeCount: 0,
- },
- },
- };
- expect(
- getUpdatedFlappingHistory(
- DISABLE_FLAPPING_SETTINGS,
- 'TEST_ALERT_0',
- state,
- false,
- true,
- false,
- ['TEST_ALERT_0']
- )
- ).toMatchInlineSnapshot(`Array []`);
- });
-});
diff --git a/x-pack/plugins/rule_registry/server/utils/get_updated_flapping_history.ts b/x-pack/plugins/rule_registry/server/utils/get_updated_flapping_history.ts
deleted file mode 100644
index 854f919722330..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/get_updated_flapping_history.ts
+++ /dev/null
@@ -1,64 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import { RuleTypeState } from '@kbn/alerting-plugin/common';
-import { RulesSettingsFlappingProperties } from '@kbn/alerting-plugin/common/rules_settings';
-import { updateFlappingHistory } from '@kbn/alerting-plugin/server/lib';
-import { remove } from 'lodash';
-import { WrappedLifecycleRuleState } from './create_lifecycle_executor';
-
-export function getUpdatedFlappingHistory(
- flappingSettings: RulesSettingsFlappingProperties,
- alertId: string,
- state: WrappedLifecycleRuleState,
- isNew: boolean,
- isRecovered: boolean,
- isActive: boolean,
- recoveredIds: string[]
-) {
- // duplicating this logic to determine flapping at this level
- let flappingHistory: boolean[] = [];
- if (flappingSettings.enabled) {
- if (isRecovered) {
- if (state.trackedAlerts[alertId]) {
- // this alert has flapped from active to recovered
- flappingHistory = updateFlappingHistory(
- flappingSettings,
- state.trackedAlerts[alertId].flappingHistory,
- true
- );
- } else if (state.trackedAlertsRecovered[alertId]) {
- // this alert is still recovered
- flappingHistory = updateFlappingHistory(
- flappingSettings,
- state.trackedAlertsRecovered[alertId].flappingHistory,
- false
- );
- }
- } else if (isNew) {
- if (state.trackedAlertsRecovered[alertId]) {
- // this alert has flapped from recovered to active
- flappingHistory = updateFlappingHistory(
- flappingSettings,
- state.trackedAlertsRecovered[alertId].flappingHistory,
- true
- );
- remove(recoveredIds, (id) => id === alertId);
- } else {
- flappingHistory = updateFlappingHistory(flappingSettings, [], true);
- }
- } else if (isActive) {
- // this alert is still active
- flappingHistory = updateFlappingHistory(
- flappingSettings,
- state.trackedAlerts[alertId].flappingHistory,
- false
- );
- }
- }
- return flappingHistory;
-}
diff --git a/x-pack/plugins/rule_registry/server/utils/lifecycle_alert_services.mock.ts b/x-pack/plugins/rule_registry/server/utils/lifecycle_alert_services.mock.ts
deleted file mode 100644
index 9324bcfd76cb4..0000000000000
--- a/x-pack/plugins/rule_registry/server/utils/lifecycle_alert_services.mock.ts
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-import { AlertInstanceContext, AlertInstanceState } from '@kbn/alerting-plugin/server';
-import { alertsMock } from '@kbn/alerting-plugin/server/mocks';
-import { LifecycleAlertServices } from './create_lifecycle_executor';
-
-/**
- * This wraps the alerts to enable the preservation of the generic type
- * arguments of the factory function.
- **/
-class AlertsMockWrapper<
- InstanceState extends AlertInstanceState = AlertInstanceState,
- InstanceContext extends AlertInstanceContext = AlertInstanceContext
-> {
- createAlertServices() {
- return alertsMock.createRuleExecutorServices();
- }
-}
-
-type AlertServices<
- InstanceState extends AlertInstanceState = AlertInstanceState,
- InstanceContext extends AlertInstanceContext = AlertInstanceContext
-> = ReturnType['createAlertServices']>;
-
-export const createLifecycleAlertServicesMock = <
- InstanceState extends AlertInstanceState = never,
- InstanceContext extends AlertInstanceContext = never,
- ActionGroupIds extends string = never
->(
- alertServices: AlertServices
-): LifecycleAlertServices => ({
- alertWithLifecycle: ({ id }) => alertServices.alertFactory.create(id),
- getAlertStartedDate: jest.fn((id: string) => null),
- getAlertUuid: jest.fn((id: string) => 'mock-alert-uuid'),
- getAlertByAlertUuid: jest.fn((id: string) => Promise.resolve(null)),
-});
diff --git a/x-pack/plugins/rule_registry/tsconfig.json b/x-pack/plugins/rule_registry/tsconfig.json
index 71f1e13a199b5..8c244ed95e014 100644
--- a/x-pack/plugins/rule_registry/tsconfig.json
+++ b/x-pack/plugins/rule_registry/tsconfig.json
@@ -34,7 +34,6 @@
"@kbn/alerts-as-data-utils",
"@kbn/core-http-router-server-mocks",
"@kbn/core-http-server",
- "@kbn/alerting-state-types",
"@kbn/alerting-types"
],
"exclude": [
diff --git a/x-pack/plugins/security_solution/common/endpoint/constants.ts b/x-pack/plugins/security_solution/common/endpoint/constants.ts
index 534d7e5c2b8a4..19aa53eca6649 100644
--- a/x-pack/plugins/security_solution/common/endpoint/constants.ts
+++ b/x-pack/plugins/security_solution/common/endpoint/constants.ts
@@ -55,6 +55,9 @@ export const telemetryIndexPattern = 'metrics-endpoint.telemetry-*';
export const ENDPOINT_HEARTBEAT_INDEX = '.logs-endpoint.heartbeat-default';
export const ENDPOINT_HEARTBEAT_INDEX_PATTERN = '.logs-endpoint.heartbeat-*';
+// Endpoint diagnostics index
+export const DEFAULT_DIAGNOSTIC_INDEX_PATTERN = '.logs-endpoint.diagnostic.collection-*' as const;
+
// File storage indexes supporting endpoint Upload/download
export const FILE_STORAGE_METADATA_INDEX = getFileMetadataIndexName('endpoint');
export const FILE_STORAGE_DATA_INDEX = getFileDataIndexName('endpoint');
diff --git a/x-pack/plugins/security_solution/common/endpoint/utils/index_name_utilities.test.ts b/x-pack/plugins/security_solution/common/endpoint/utils/index_name_utilities.test.ts
new file mode 100644
index 0000000000000..25eb35bf88872
--- /dev/null
+++ b/x-pack/plugins/security_solution/common/endpoint/utils/index_name_utilities.test.ts
@@ -0,0 +1,19 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import { buildIndexNameWithNamespace } from './index_name_utilities';
+
+describe('index name utilities', () => {
+ describe('buildIndexNameWithNamespace()', () => {
+ test.each(['logs-endpoint.foo', 'logs-endpoint.foo-', 'logs-endpoint.foo-*'])(
+ `should build correct index name for: %s`,
+ (prefix) => {
+ expect(buildIndexNameWithNamespace(prefix, 'bar')).toEqual('logs-endpoint.foo-bar');
+ }
+ );
+ });
+});
diff --git a/x-pack/plugins/security_solution/common/endpoint/utils/index_name_utilities.ts b/x-pack/plugins/security_solution/common/endpoint/utils/index_name_utilities.ts
new file mode 100644
index 0000000000000..80db5392f653f
--- /dev/null
+++ b/x-pack/plugins/security_solution/common/endpoint/utils/index_name_utilities.ts
@@ -0,0 +1,34 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+/**
+ * Builds an index name that includes the `namespace` using the provided index name prefix or pattern.
+ *
+ * @param indexNamePrefixOrPattern
+ * @param namespace
+ *
+ * @example
+ *
+ * buildIndexNameWithNamespace('logs-foo.bar-*', 'default'); // == 'logs-foo.bar-default'
+ * buildIndexNameWithNamespace('logs-foo.bar', 'default'); // == 'logs-foo.bar-default'
+ * buildIndexNameWithNamespace('logs-foo.bar-', 'default'); // == 'logs-foo.bar-default'
+ */
+export const buildIndexNameWithNamespace = (
+ indexNamePrefixOrPattern: string,
+ namespace: string
+): string => {
+ if (indexNamePrefixOrPattern.endsWith('*')) {
+ const hasDash = indexNamePrefixOrPattern.endsWith('-*');
+ return `${indexNamePrefixOrPattern.substring(0, indexNamePrefixOrPattern.length - 1)}${
+ hasDash ? '' : '-'
+ }${namespace}`;
+ }
+
+ return `${indexNamePrefixOrPattern}${
+ indexNamePrefixOrPattern.endsWith('-') ? '' : '-'
+ }${namespace}`;
+};
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/alerts/alerts_card.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/alerts/alerts_card.tsx
index c0369ed23d61c..85d3994d44530 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/alerts/alerts_card.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/alerts/alerts_card.tsx
@@ -6,7 +6,16 @@
*/
import React, { useCallback, useMemo } from 'react';
-import { EuiFlexGroup, EuiFlexItem, EuiIcon, EuiLink, EuiSpacer, EuiText } from '@elastic/eui';
+import {
+ EuiFlexGroup,
+ EuiFlexItem,
+ EuiIcon,
+ EuiLink,
+ EuiSpacer,
+ EuiText,
+ useEuiTheme,
+ COLOR_MODES_STANDARD,
+} from '@elastic/eui';
import { SecurityPageName } from '@kbn/security-solution-navigation';
import { SecuritySolutionLinkButton } from '../../../../../common/components/links';
import { OnboardingCardId } from '../../../../constants';
@@ -21,6 +30,9 @@ export const AlertsCard: OnboardingCardComponent = ({
setExpandedCardId,
setComplete,
}) => {
+ const { colorMode } = useEuiTheme();
+ const isDarkMode = colorMode === COLOR_MODES_STANDARD.dark;
+
const isIntegrationsCardComplete = useMemo(
() => isCardComplete(OnboardingCardId.integrations),
[isCardComplete]
@@ -39,7 +51,11 @@ export const AlertsCard: OnboardingCardComponent = ({
alignItems="flexStart"
>
-
+
{i18n.ALERTS_CARD_DESCRIPTION}
{!isIntegrationsCardComplete && (
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_card.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_card.tsx
index 4b87f23dd2435..b728606937020 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_card.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_card.tsx
@@ -6,7 +6,16 @@
*/
import React, { useCallback, useMemo } from 'react';
-import { EuiFlexGroup, EuiFlexItem, EuiIcon, EuiLink, EuiText } from '@elastic/eui';
+import {
+ EuiCallOut,
+ EuiFlexGroup,
+ EuiFlexItem,
+ EuiIcon,
+ EuiLink,
+ EuiText,
+ useEuiTheme,
+ COLOR_MODES_STANDARD,
+} from '@elastic/eui';
import { css } from '@emotion/css';
import { OnboardingCardId } from '../../../../constants';
import type { OnboardingCardComponent } from '../../../../types';
@@ -15,6 +24,7 @@ import { OnboardingCardContentPanel } from '../common/card_content_panel';
import { ConnectorCards } from './connectors/connector_cards';
import { CardCallOut } from '../common/card_callout';
import type { AssistantCardMetadata } from './types';
+import { MissingPrivilegesDescription } from './connectors/missing_privileges_tooltip';
export const AssistantCard: OnboardingCardComponent = ({
isCardComplete,
@@ -22,6 +32,8 @@ export const AssistantCard: OnboardingCardComponent = ({
checkCompleteMetadata,
checkComplete,
}) => {
+ const { euiTheme, colorMode } = useEuiTheme();
+ const isDarkMode = colorMode === COLOR_MODES_STANDARD.dark;
const isIntegrationsCardComplete = useMemo(
() => isCardComplete(OnboardingCardId.integrations),
[isCardComplete]
@@ -32,43 +44,60 @@ export const AssistantCard: OnboardingCardComponent = ({
}, [setExpandedCardId]);
const connectors = checkCompleteMetadata?.connectors;
+ const canExecuteConnectors = checkCompleteMetadata?.canExecuteConnectors;
+ const canCreateConnectors = checkCompleteMetadata?.canCreateConnectors;
return (
-
-
-
-
- {i18n.ASSISTANT_CARD_DESCRIPTION}
-
-
-
- {isIntegrationsCardComplete ? (
-
- ) : (
-
-
-
- {i18n.ASSISTANT_CARD_CALLOUT_INTEGRATIONS_BUTTON}
-
-
-
-
-
- }
+
+ {canExecuteConnectors ? (
+
+
+
+ {i18n.ASSISTANT_CARD_DESCRIPTION}
+
+
+
+ {isIntegrationsCardComplete ? (
+
-
- )}
-
-
+ ) : (
+
+
+
+ {i18n.ASSISTANT_CARD_CALLOUT_INTEGRATIONS_BUTTON}
+
+
+
+
+
+ }
+ />
+
+ )}
+
+
+ ) : (
+
+
+
+ )}
);
};
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_check_complete.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_check_complete.ts
index bdb52b3a0e614..8c0d029cee583 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_check_complete.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/assistant_check_complete.ts
@@ -14,8 +14,11 @@ import type { AssistantCardMetadata } from './types';
export const checkAssistantCardComplete: OnboardingCardCheckComplete<
AssistantCardMetadata
-> = async ({ http }) => {
+> = async ({ http, application }) => {
const allConnectors = await loadConnectors({ http });
+ const {
+ capabilities: { actions },
+ } = application;
const aiConnectors = allConnectors.reduce((acc: AIConnector[], connector) => {
if (!connector.isMissingSecrets && AllowedActionTypeIds.includes(connector.actionTypeId)) {
@@ -37,6 +40,8 @@ export const checkAssistantCardComplete: OnboardingCardCheckComplete<
completeBadgeText,
metadata: {
connectors: aiConnectors,
+ canExecuteConnectors: Boolean(actions?.show && actions?.execute),
+ canCreateConnectors: Boolean(actions?.save),
},
};
};
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/connector_cards.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/connector_cards.tsx
index 3cdefaa1fe490..472459b631b0a 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/connector_cards.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/connector_cards.tsx
@@ -15,69 +15,104 @@ import {
EuiText,
EuiBadge,
EuiSpacer,
+ EuiCallOut,
} from '@elastic/eui';
import { css } from '@emotion/css';
import { useKibana } from '../../../../../../common/lib/kibana';
import { CreateConnectorPopover } from './create_connector_popover';
import { ConnectorSetup } from './connector_setup';
+import * as i18n from './translations';
+import { MissingPrivilegesDescription } from './missing_privileges_tooltip';
interface ConnectorCardsProps {
connectors?: AIConnector[];
onConnectorSaved: () => void;
+ canCreateConnectors?: boolean;
}
export const ConnectorCards = React.memo(
- ({ connectors, onConnectorSaved }) => {
+ ({ connectors, onConnectorSaved, canCreateConnectors }) => {
const {
triggersActionsUi: { actionTypeRegistry },
} = useKibana().services;
- if (!connectors) return ;
+ if (!connectors) {
+ return ;
+ }
+
+ const hasConnectors = connectors.length > 0;
- if (connectors.length > 0) {
+ // show callout when user is missing actions.save privilege
+ if (!hasConnectors && !canCreateConnectors) {
return (
- <>
-
- {connectors.map((connector) => (
-
-
-
-
- {connector.name}
-
-
-
- {actionTypeRegistry.get(connector.actionTypeId).actionTypeTitle}
-
-
-
-
-
- ))}
-
-
-
- >
+
+
+
);
}
- return ;
+ return (
+ <>
+ {hasConnectors ? (
+ <>
+
+
+
+ >
+ ) : (
+
+ )}
+ >
+ );
}
);
ConnectorCards.displayName = 'ConnectorCards';
+
+interface ConnectorListProps {
+ connectors: AIConnector[];
+ actionTypeRegistry: ReturnType<
+ typeof useKibana
+ >['services']['triggersActionsUi']['actionTypeRegistry'];
+}
+
+const ConnectorList = React.memo(({ connectors, actionTypeRegistry }) => (
+
+ {connectors.map((connector) => (
+
+
+
+
+ {connector.name}
+
+
+
+ {actionTypeRegistry.get(connector.actionTypeId).actionTypeTitle}
+
+
+
+
+
+ ))}
+
+));
+
+ConnectorList.displayName = 'ConnectorList';
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/create_connector_popover.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/create_connector_popover.tsx
index de432d6597afd..32bcd66f49249 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/create_connector_popover.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/create_connector_popover.tsx
@@ -8,14 +8,16 @@ import React, { useCallback, useState } from 'react';
import { css } from '@emotion/css';
import { EuiPopover, EuiLink, EuiText } from '@elastic/eui';
import { ConnectorSetup } from './connector_setup';
-import * as i18n from '../translations';
+import * as i18n from './translations';
+import { MissingPrivilegesTooltip } from './missing_privileges_tooltip';
interface CreateConnectorPopoverProps {
onConnectorSaved: () => void;
+ canCreateConnectors?: boolean;
}
export const CreateConnectorPopover = React.memo(
- ({ onConnectorSaved }) => {
+ ({ onConnectorSaved, canCreateConnectors }) => {
const [isOpen, setIsPopoverOpen] = useState(false);
const closePopover = useCallback(() => setIsPopoverOpen(false), []);
@@ -23,6 +25,15 @@ export const CreateConnectorPopover = React.memo(
() => setIsPopoverOpen((isPopoverOpen) => !isPopoverOpen),
[]
);
+ if (!canCreateConnectors) {
+ return (
+
+
+ {i18n.ASSISTANT_CARD_CREATE_NEW_CONNECTOR_POPOVER}
+
+
+ );
+ }
return (
(({ children }) => (
+ }
+ >
+ {children}
+
+));
+MissingPrivilegesTooltip.displayName = 'MissingPrivilegesTooltip';
+
+export const MissingPrivilegesDescription = React.memo(() => {
+ return (
+
+ {i18n.PRIVILEGES_REQUIRED_TITLE}
+
+
+
+ - {i18n.REQUIRED_PRIVILEGES_CONNECTORS_ALL}
+
+
+
+ {i18n.CONTACT_ADMINISTRATOR}
+
+ );
+});
+MissingPrivilegesDescription.displayName = 'MissingPrivilegesDescription';
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/translations.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/translations.ts
new file mode 100644
index 0000000000000..983a6a67f5b32
--- /dev/null
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/connectors/translations.ts
@@ -0,0 +1,43 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import { i18n } from '@kbn/i18n';
+
+export const ASSISTANT_CARD_CREATE_NEW_CONNECTOR_POPOVER = i18n.translate(
+ 'xpack.securitySolution.onboarding.assistantCard.createNewConnectorPopover',
+ {
+ defaultMessage: 'Create new connector',
+ }
+);
+
+export const PRIVILEGES_MISSING_TITLE = i18n.translate(
+ 'xpack.securitySolution.onboarding.assistantCard.missingPrivileges.title',
+ {
+ defaultMessage: 'Missing privileges',
+ }
+);
+
+export const PRIVILEGES_REQUIRED_TITLE = i18n.translate(
+ 'xpack.securitySolution.onboarding.assistantCard.requiredPrivileges',
+ {
+ defaultMessage: 'The minimum Kibana privileges required to use this feature are:',
+ }
+);
+
+export const REQUIRED_PRIVILEGES_CONNECTORS_ALL = i18n.translate(
+ 'xpack.securitySolution.onboarding.assistantCard.requiredPrivileges.connectorsAll',
+ {
+ defaultMessage: 'Management > Connectors: All',
+ }
+);
+
+export const CONTACT_ADMINISTRATOR = i18n.translate(
+ 'xpack.securitySolution.onboarding.assistantCard.missingPrivileges.contactAdministrator',
+ {
+ defaultMessage: 'Contact your administrator for assistance.',
+ }
+);
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/index.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/index.ts
index 27deda4190f2e..fedf975052327 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/index.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/index.ts
@@ -27,6 +27,6 @@ export const assistantCardConfig: OnboardingCardConfig =
checkComplete: checkAssistantCardComplete,
// Both capabilities are needed for this card, so we should use a double array to create an AND conditional
// (a single array would create an OR conditional between them)
- capabilities: [['securitySolutionAssistant.ai-assistant', 'actions.show']],
+ capabilities: [['securitySolutionAssistant.ai-assistant']],
licenseType: 'enterprise',
};
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/translations.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/translations.ts
index 41e73bdacf061..de3c111280436 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/translations.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/translations.ts
@@ -42,3 +42,10 @@ export const ASSISTANT_CARD_CREATE_NEW_CONNECTOR_POPOVER = i18n.translate(
defaultMessage: 'Create new connector',
}
);
+
+export const PRIVILEGES_MISSING_TITLE = i18n.translate(
+ 'xpack.securitySolution.onboarding.assistantCard.callout.title',
+ {
+ defaultMessage: 'Missing privileges',
+ }
+);
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/types.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/types.ts
index f1e0216406391..d6647adf054fe 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/types.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/assistant/types.ts
@@ -9,4 +9,6 @@ import type { ActionConnector } from '@kbn/alerts-ui-shared';
export interface AssistantCardMetadata {
connectors: ActionConnector[];
+ canExecuteConnectors: boolean;
+ canCreateConnectors: boolean;
}
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/common/card_content_image_panel.styles.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/common/card_content_image_panel.styles.ts
index d8f6d6c278ee3..c7998135aa8ae 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/common/card_content_image_panel.styles.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/common/card_content_image_panel.styles.ts
@@ -6,13 +6,15 @@
*/
import { css } from '@emotion/css';
-import { useEuiTheme, useEuiShadow } from '@elastic/eui';
+import { useEuiTheme, useEuiShadow, COLOR_MODES_STANDARD } from '@elastic/eui';
export const useCardContentImagePanelStyles = () => {
- const { euiTheme } = useEuiTheme();
+ const { euiTheme, colorMode } = useEuiTheme();
const shadowStyles = useEuiShadow('m');
+ const isDarkMode = colorMode === COLOR_MODES_STANDARD.dark;
return css`
padding-top: 8px;
+ ${isDarkMode ? `background-color: ${euiTheme.colors.lightestShade}` : ''};
.cardSpacer {
width: 8%;
}
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/dashboards/dashboards_card.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/dashboards/dashboards_card.tsx
index df98800d83f32..201aa4f0d3150 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/dashboards/dashboards_card.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/dashboards/dashboards_card.tsx
@@ -6,7 +6,16 @@
*/
import React, { useCallback, useMemo } from 'react';
-import { EuiFlexGroup, EuiFlexItem, EuiIcon, EuiLink, EuiSpacer, EuiText } from '@elastic/eui';
+import {
+ EuiFlexGroup,
+ EuiFlexItem,
+ EuiIcon,
+ EuiLink,
+ EuiSpacer,
+ EuiText,
+ useEuiTheme,
+ COLOR_MODES_STANDARD,
+} from '@elastic/eui';
import { SecurityPageName } from '@kbn/security-solution-navigation';
import { OnboardingCardId } from '../../../../constants';
import type { OnboardingCardComponent } from '../../../../types';
@@ -21,6 +30,9 @@ export const DashboardsCard: OnboardingCardComponent = ({
setComplete,
setExpandedCardId,
}) => {
+ const { colorMode } = useEuiTheme();
+ const isDarkMode = colorMode === COLOR_MODES_STANDARD.dark;
+
const isIntegrationsCardComplete = useMemo(
() => isCardComplete(OnboardingCardId.integrations),
[isCardComplete]
@@ -42,7 +54,11 @@ export const DashboardsCard: OnboardingCardComponent = ({
alignItems="flexStart"
>
-
+
{i18n.DASHBOARDS_CARD_DESCRIPTION}
{!isIntegrationsCardComplete && (
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/rules/rules_card.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/rules/rules_card.tsx
index 7f283c0ffbc78..50c722d49c359 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/rules/rules_card.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_body/cards/rules/rules_card.tsx
@@ -6,7 +6,16 @@
*/
import React, { useCallback, useMemo } from 'react';
-import { EuiFlexGroup, EuiFlexItem, EuiIcon, EuiLink, EuiSpacer, EuiText } from '@elastic/eui';
+import {
+ EuiFlexGroup,
+ EuiFlexItem,
+ EuiIcon,
+ EuiLink,
+ EuiSpacer,
+ EuiText,
+ useEuiTheme,
+ COLOR_MODES_STANDARD,
+} from '@elastic/eui';
import { SecurityPageName } from '@kbn/security-solution-navigation';
import { SecuritySolutionLinkButton } from '../../../../../common/components/links';
import { OnboardingCardId } from '../../../../constants';
@@ -17,6 +26,9 @@ import rulesImageSrc from './images/rules.png';
import * as i18n from './translations';
export const RulesCard: OnboardingCardComponent = ({ isCardComplete, setExpandedCardId }) => {
+ const { colorMode } = useEuiTheme();
+ const isDarkMode = colorMode === COLOR_MODES_STANDARD.dark;
+
const isIntegrationsCardComplete = useMemo(
() => isCardComplete(OnboardingCardId.integrations),
[isCardComplete]
@@ -35,7 +47,11 @@ export const RulesCard: OnboardingCardComponent = ({ isCardComplete, setExpanded
alignItems="flexStart"
>
-
+
{i18n.RULES_CARD_DESCRIPTION}
{!isIntegrationsCardComplete && (
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/constants.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/constants.ts
index f67b991e0ea75..722dfad89fc5b 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/constants.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/constants.ts
@@ -8,7 +8,6 @@
export const TELEMETRY_FOOTER_LINK = `footer_link`;
export enum OnboardingFooterLinkItemId {
- video = 'video',
documentation = 'documentation',
demo = 'demo',
forum = 'forum',
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/footer_items.ts b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/footer_items.ts
index f064947f657a4..40a6e01f6c037 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/footer_items.ts
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/footer_items.ts
@@ -5,78 +5,90 @@
* 2.0.
*/
import { i18n } from '@kbn/i18n';
-import documentation from './images/documentation.png';
-import forum from './images/forum.png';
-import demo from './images/demo.png';
-import labs from './images/labs.png';
+import { COLOR_MODES_STANDARD, useEuiTheme } from '@elastic/eui';
+import documentationImage from './images/documentation.png';
+import darkDocumentationImage from './images/documentation_dark.png';
+import forumImage from './images/forum.png';
+import darkForumImge from './images/forum_dark.png';
+import demoImage from './images/demo.png';
+import darkDemoImage from './images/demo_dark.png';
+import labsImage from './images/labs.png';
+import darkLabsImage from './images/labs_dark.png';
import { OnboardingFooterLinkItemId } from './constants';
-export const footerItems = [
- {
- icon: documentation,
- id: OnboardingFooterLinkItemId.documentation,
- title: i18n.translate('xpack.securitySolution.onboarding.footer.documentation.title', {
- defaultMessage: 'Browse documentation',
- }),
- description: i18n.translate(
- 'xpack.securitySolution.onboarding.footer.documentation.description',
- {
- defaultMessage: 'In-depth guides on all Elastic features',
- }
- ),
- link: {
- title: i18n.translate('xpack.securitySolution.onboarding.footer.documentation.link.title', {
- defaultMessage: 'Start reading',
+export const useFooterItems = () => {
+ const { colorMode } = useEuiTheme();
+ const isDarkMode = colorMode === COLOR_MODES_STANDARD.dark;
+
+ const footerItems = [
+ {
+ icon: isDarkMode ? darkDocumentationImage : documentationImage,
+ id: OnboardingFooterLinkItemId.documentation,
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.documentation.title', {
+ defaultMessage: 'Browse documentation',
}),
- href: 'https://docs.elastic.co/integrations/elastic-security-intro',
+ description: i18n.translate(
+ 'xpack.securitySolution.onboarding.footer.documentation.description',
+ {
+ defaultMessage: 'In-depth guides on all Elastic features',
+ }
+ ),
+ link: {
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.documentation.link.title', {
+ defaultMessage: 'Start reading',
+ }),
+ href: 'https://docs.elastic.co/integrations/elastic-security-intro',
+ },
},
- },
- {
- icon: forum,
- id: OnboardingFooterLinkItemId.forum,
- title: i18n.translate('xpack.securitySolution.onboarding.footer.forum.title', {
- defaultMessage: 'Explore forum',
- }),
- description: i18n.translate('xpack.securitySolution.onboarding.footer.forum.description', {
- defaultMessage: 'Exchange thoughts about Elastic',
- }),
- link: {
- title: i18n.translate('xpack.securitySolution.onboarding.footer.forum.link.title', {
- defaultMessage: 'Discuss Forum',
+ {
+ icon: isDarkMode ? darkForumImge : forumImage,
+ id: OnboardingFooterLinkItemId.forum,
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.forum.title', {
+ defaultMessage: 'Explore forum',
+ }),
+ description: i18n.translate('xpack.securitySolution.onboarding.footer.forum.description', {
+ defaultMessage: 'Exchange thoughts about Elastic',
}),
- href: 'https://discuss.elastic.co/c/security/83',
+ link: {
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.forum.link.title', {
+ defaultMessage: 'Discuss Forum',
+ }),
+ href: 'https://discuss.elastic.co/c/security/83',
+ },
},
- },
- {
- icon: demo,
- id: OnboardingFooterLinkItemId.demo,
- title: i18n.translate('xpack.securitySolution.onboarding.footer.demo.title', {
- defaultMessage: 'View demo project',
- }),
- description: i18n.translate('xpack.securitySolution.onboarding.footer.demo.description', {
- defaultMessage: 'Discover Elastic using sample data',
- }),
- link: {
- title: i18n.translate('xpack.securitySolution.onboarding.footer.demo.link.title', {
- defaultMessage: 'Explore demo',
+ {
+ icon: isDarkMode ? darkDemoImage : demoImage,
+ id: OnboardingFooterLinkItemId.demo,
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.demo.title', {
+ defaultMessage: 'View demo project',
+ }),
+ description: i18n.translate('xpack.securitySolution.onboarding.footer.demo.description', {
+ defaultMessage: 'Discover Elastic using sample data',
}),
- href: 'https://www.elastic.co/demo-gallery?solutions=security&features=null',
+ link: {
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.demo.link.title', {
+ defaultMessage: 'Explore demo',
+ }),
+ href: 'https://www.elastic.co/demo-gallery?solutions=security&features=null',
+ },
},
- },
- {
- icon: labs,
- id: OnboardingFooterLinkItemId.labs,
- title: i18n.translate('xpack.securitySolution.onboarding.footer.labs.title', {
- defaultMessage: 'Elastic Security Labs',
- }),
- description: i18n.translate('xpack.securitySolution.onboarding.footer.labs.description', {
- defaultMessage: 'Insights from security researchers',
- }),
- link: {
- title: i18n.translate('xpack.securitySolution.onboarding.footer.labs.link.title', {
- defaultMessage: 'Learn more',
+ {
+ icon: isDarkMode ? darkLabsImage : labsImage,
+ id: OnboardingFooterLinkItemId.labs,
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.labs.title', {
+ defaultMessage: 'Elastic Security Labs',
}),
- href: 'https://www.elastic.co/security-labs',
+ description: i18n.translate('xpack.securitySolution.onboarding.footer.labs.description', {
+ defaultMessage: 'Insights from security researchers',
+ }),
+ link: {
+ title: i18n.translate('xpack.securitySolution.onboarding.footer.labs.link.title', {
+ defaultMessage: 'Learn more',
+ }),
+ href: 'https://www.elastic.co/security-labs',
+ },
},
- },
-] as const;
+ ] as const;
+
+ return footerItems;
+};
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/demo_dark.png b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/demo_dark.png
new file mode 100644
index 0000000000000..fb90f857c0694
Binary files /dev/null and b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/demo_dark.png differ
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/documentation_dark.png b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/documentation_dark.png
new file mode 100644
index 0000000000000..8692b53f96ea5
Binary files /dev/null and b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/documentation_dark.png differ
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/forum_dark.png b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/forum_dark.png
new file mode 100644
index 0000000000000..3ede58eeeaa3a
Binary files /dev/null and b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/forum_dark.png differ
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/labs_dark.png b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/labs_dark.png
new file mode 100644
index 0000000000000..846137fe4187b
Binary files /dev/null and b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/images/labs_dark.png differ
diff --git a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/onboarding_footer.tsx b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/onboarding_footer.tsx
index fdf743d339a60..125d2af118d3f 100644
--- a/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/onboarding_footer.tsx
+++ b/x-pack/plugins/security_solution/public/onboarding/components/onboarding_footer/onboarding_footer.tsx
@@ -8,13 +8,14 @@
import React, { useCallback } from 'react';
import { EuiFlexGroup, EuiFlexItem, EuiLink, EuiSpacer, EuiText, EuiTitle } from '@elastic/eui';
import { useFooterStyles } from './onboarding_footer.styles';
-import { footerItems } from './footer_items';
+import { useFooterItems } from './footer_items';
import { trackOnboardingLinkClick } from '../../common/lib/telemetry';
import type { OnboardingFooterLinkItemId } from './constants';
import { TELEMETRY_FOOTER_LINK } from './constants';
export const OnboardingFooter = React.memo(() => {
const styles = useFooterStyles();
+ const footerItems = useFooterItems();
return (
{footerItems.map(({ id, title, icon, description, link }) => (
diff --git a/x-pack/plugins/security_solution/scripts/endpoint/common/fleet_services.ts b/x-pack/plugins/security_solution/scripts/endpoint/common/fleet_services.ts
index 92c13a521ed2c..a07823194fa69 100644
--- a/x-pack/plugins/security_solution/scripts/endpoint/common/fleet_services.ts
+++ b/x-pack/plugins/security_solution/scripts/endpoint/common/fleet_services.ts
@@ -21,10 +21,12 @@ import type {
GetAgentsResponse,
GetInfoResponse,
GetOneAgentPolicyResponse,
+ GetOnePackagePolicyResponse,
GetPackagePoliciesRequest,
GetPackagePoliciesResponse,
PackagePolicy,
PostFleetSetupResponse,
+ UpdatePackagePolicyResponse,
} from '@kbn/fleet-plugin/common';
import {
AGENT_API_ROUTES,
@@ -39,6 +41,7 @@ import {
PACKAGE_POLICY_API_ROUTES,
PACKAGE_POLICY_SAVED_OBJECT_TYPE,
SETUP_API_ROUTE,
+ packagePolicyRouteService,
} from '@kbn/fleet-plugin/common';
import type { ToolingLog } from '@kbn/tooling-log';
import type { KbnClient } from '@kbn/test';
@@ -57,11 +60,14 @@ import type {
GetEnrollmentAPIKeysResponse,
GetOutputsResponse,
PostAgentUnenrollResponse,
+ UpdateAgentPolicyRequest,
+ UpdateAgentPolicyResponse,
} from '@kbn/fleet-plugin/common/types';
import semver from 'semver';
import axios from 'axios';
import { userInfo } from 'os';
import pRetry from 'p-retry';
+import { getPolicyDataForUpdate } from '../../../common/endpoint/service/policy';
import { fetchActiveSpace } from './spaces';
import { fetchKibanaStatus } from '../../../common/endpoint/utils/kibana_status';
import { isFleetServerRunning } from './fleet_server/fleet_server_services';
@@ -76,6 +82,7 @@ import {
} from '../../../common/endpoint/data_loaders/utils';
import { catchAxiosErrorFormatAndThrow } from '../../../common/endpoint/format_axios_error';
import { FleetAgentGenerator } from '../../../common/endpoint/data_generators/fleet_agent_generator';
+import type { PolicyData } from '../../../common/endpoint/types';
const fleetGenerator = new FleetAgentGenerator();
const CURRENT_USERNAME = userInfo().username.toLowerCase();
@@ -101,6 +108,39 @@ export const randomAgentPolicyName = (() => {
*/
const isValidArtifactVersion = (version: string) => !!version.match(/^\d+\.\d+\.\d+(-SNAPSHOT)?$/);
+const getAgentPolicyDataForUpdate = (
+ agentPolicy: AgentPolicy
+): UpdateAgentPolicyRequest['body'] => {
+ return pick(agentPolicy, [
+ 'advanced_settings',
+ 'agent_features',
+ 'data_output_id',
+ 'description',
+ 'download_source_id',
+ 'fleet_server_host_id',
+ 'global_data_tags',
+ 'has_fleet_server',
+ 'id',
+ 'inactivity_timeout',
+ 'is_default',
+ 'is_default_fleet_server',
+ 'is_managed',
+ 'is_protected',
+ 'keep_monitoring_alive',
+ 'monitoring_diagnostics',
+ 'monitoring_enabled',
+ 'monitoring_http',
+ 'monitoring_output_id',
+ 'monitoring_pprof_enabled',
+ 'name',
+ 'namespace',
+ 'overrides',
+ 'space_ids',
+ 'supports_agentless',
+ 'unenroll_timeout',
+ ]) as UpdateAgentPolicyRequest['body'];
+};
+
export const checkInFleetAgent = async (
esClient: Client,
agentId: string,
@@ -1369,3 +1409,93 @@ export const enableFleetSpaceAwareness = memoize(async (kbnClient: KbnClient): P
})
.catch(catchAxiosErrorFormatAndThrow);
});
+
+/**
+ * Fetches a single integratino policy by id
+ * @param kbnClient
+ * @param policyId
+ */
+export const fetchIntegrationPolicy = async (
+ kbnClient: KbnClient,
+ policyId: string
+): Promise => {
+ return kbnClient
+ .request({
+ path: packagePolicyRouteService.getInfoPath(policyId),
+ method: 'GET',
+ headers: { 'elastic-api-version': '2023-10-31' },
+ })
+ .catch(catchAxiosErrorFormatAndThrow)
+ .then((response) => response.data.item);
+};
+
+/**
+ * Update a fleet integration policy (aka: package policy)
+ * @param kbnClient
+ */
+export const updateIntegrationPolicy = async (
+ kbnClient: KbnClient,
+ /** The Integration policy id */
+ id: string,
+ policyData: Partial,
+ /** If set to `true`, then `policyData` can be a partial set of updates and not the full policy data */
+ patch: boolean = false
+): Promise => {
+ let fullPolicyData = policyData;
+
+ if (patch) {
+ const currentSavedPolicy = await fetchIntegrationPolicy(kbnClient, id);
+ fullPolicyData = getPolicyDataForUpdate(currentSavedPolicy as PolicyData);
+ Object.assign(fullPolicyData, policyData);
+ }
+
+ return kbnClient
+ .request({
+ path: packagePolicyRouteService.getUpdatePath(id),
+ method: 'PUT',
+ body: fullPolicyData,
+ headers: { 'elastic-api-version': '2023-10-31' },
+ })
+ .catch(catchAxiosErrorFormatAndThrow)
+ .then((response) => response.data.item);
+};
+
+/**
+ * Updates a Fleet agent policy
+ * @param kbnClient
+ * @param id
+ * @param policyData
+ * @param patch
+ */
+export const updateAgentPolicy = async (
+ kbnClient: KbnClient,
+ /** Fleet Agent Policy ID */
+ id: string,
+ /** The updated agent policy data. Could be a `partial` update if `patch` arguments below is true */
+ policyData: Partial,
+ /**
+ * If set to `true`, the `policyData` provided on input will first be merged with the latest version
+ * of the policy and then the updated applied
+ */
+ patch: boolean = false
+): Promise => {
+ let fullPolicyData = policyData;
+
+ if (patch) {
+ const currentSavedPolicy = await fetchAgentPolicy(kbnClient, id);
+
+ fullPolicyData = getAgentPolicyDataForUpdate(currentSavedPolicy);
+ delete fullPolicyData.id;
+ Object.assign(fullPolicyData, policyData);
+ }
+
+ return kbnClient
+ .request({
+ path: agentPolicyRouteService.getUpdatePath(id),
+ method: 'PUT',
+ body: fullPolicyData,
+ headers: { 'elastic-api-version': '2023-10-31' },
+ })
+ .catch(catchAxiosErrorFormatAndThrow)
+ .then((response) => response.data.item);
+};
diff --git a/x-pack/plugins/security_solution/server/fleet_integration/handlers/create_policy_datastreams.ts b/x-pack/plugins/security_solution/server/fleet_integration/handlers/create_policy_datastreams.ts
index a113c68e4132d..e94bc71cd4fa7 100644
--- a/x-pack/plugins/security_solution/server/fleet_integration/handlers/create_policy_datastreams.ts
+++ b/x-pack/plugins/security_solution/server/fleet_integration/handlers/create_policy_datastreams.ts
@@ -6,33 +6,18 @@
*/
import pMap from 'p-map';
+import { buildIndexNameWithNamespace } from '../../../common/endpoint/utils/index_name_utilities';
import type { EndpointAppContextService } from '../../endpoint/endpoint_app_context_services';
import { catchAndWrapError } from '../../endpoint/utils';
import type { SimpleMemCacheInterface } from '../../endpoint/lib/simple_mem_cache';
import { SimpleMemCache } from '../../endpoint/lib/simple_mem_cache';
import {
+ DEFAULT_DIAGNOSTIC_INDEX_PATTERN,
ENDPOINT_ACTION_RESPONSES_DS,
ENDPOINT_HEARTBEAT_INDEX_PATTERN,
} from '../../../common/endpoint/constants';
-import { DEFAULT_DIAGNOSTIC_INDEX } from '../../lib/telemetry/constants';
import { stringify } from '../../endpoint/utils/stringify';
-const buildIndexNameWithNamespace = (
- indexNamePrefixOrPattern: string,
- namespace: string
-): string => {
- if (indexNamePrefixOrPattern.endsWith('*')) {
- const hasDash = indexNamePrefixOrPattern.endsWith('-*');
- return `${indexNamePrefixOrPattern.substring(0, indexNamePrefixOrPattern.length - 1)}${
- hasDash ? '' : '-'
- }${namespace}`;
- }
-
- return `${indexNamePrefixOrPattern}${
- indexNamePrefixOrPattern.endsWith('-') ? '' : '-'
- }${namespace}`;
-};
-
const cache = new SimpleMemCache({
// Cache of created Datastreams last for 12h, at which point it is checked again.
// This is just a safeguard case (for whatever reason) the index is deleted
@@ -81,7 +66,7 @@ export const createPolicyDataStreamsIfNeeded: PolicyDataStreamsCreator = async (
const indicesToCreate: string[] = Array.from(
Object.values(policyNamespaces.integrationPolicy).reduce>((acc, namespaceList) => {
for (const namespace of namespaceList) {
- acc.add(buildIndexNameWithNamespace(DEFAULT_DIAGNOSTIC_INDEX, namespace));
+ acc.add(buildIndexNameWithNamespace(DEFAULT_DIAGNOSTIC_INDEX_PATTERN, namespace));
acc.add(buildIndexNameWithNamespace(ENDPOINT_ACTION_RESPONSES_DS, namespace));
if (endpointServices.isServerless()) {
diff --git a/x-pack/plugins/security_solution/server/integration_tests/lib/telemetry_helpers.ts b/x-pack/plugins/security_solution/server/integration_tests/lib/telemetry_helpers.ts
index d83ff1e910ca5..a36d5e1be38de 100644
--- a/x-pack/plugins/security_solution/server/integration_tests/lib/telemetry_helpers.ts
+++ b/x-pack/plugins/security_solution/server/integration_tests/lib/telemetry_helpers.ts
@@ -30,6 +30,7 @@ import { packagePolicyService } from '@kbn/fleet-plugin/server/services';
import { ENDPOINT_ARTIFACT_LISTS } from '@kbn/securitysolution-list-constants';
import { DETECTION_TYPE, NAMESPACE_TYPE } from '@kbn/lists-plugin/common/constants.mock';
+import { DEFAULT_DIAGNOSTIC_INDEX_PATTERN } from '../../../common/endpoint/constants';
import { bulkInsert, updateTimestamps } from './helpers';
import { TelemetryEventsSender } from '../../lib/telemetry/sender';
import type {
@@ -40,7 +41,6 @@ import type { SecurityTelemetryTask } from '../../lib/telemetry/task';
import { Plugin as SecuritySolutionPlugin } from '../../plugin';
import { AsyncTelemetryEventsSender } from '../../lib/telemetry/async_sender';
import { type ITelemetryReceiver, TelemetryReceiver } from '../../lib/telemetry/receiver';
-import { DEFAULT_DIAGNOSTIC_INDEX } from '../../lib/telemetry/constants';
import mockEndpointAlert from '../__mocks__/endpoint-alert.json';
import mockedRule from '../__mocks__/rule.json';
import fleetAgents from '../__mocks__/fleet-agents.json';
@@ -147,7 +147,7 @@ export function getTelemetryTask(
}
export async function createMockedEndpointAlert(esClient: ElasticsearchClient) {
- const index = `${DEFAULT_DIAGNOSTIC_INDEX.replace('-*', '')}-001`;
+ const index = `${DEFAULT_DIAGNOSTIC_INDEX_PATTERN.replace('-*', '')}-001`;
await esClient.indices.create({ index, body: { settings: { hidden: true } } });
@@ -223,7 +223,7 @@ export async function dropEndpointIndices(esClient: ElasticsearchClient) {
}
export async function cleanupMockedEndpointAlerts(esClient: ElasticsearchClient) {
- const index = `${DEFAULT_DIAGNOSTIC_INDEX.replace('-*', '')}-001`;
+ const index = `${DEFAULT_DIAGNOSTIC_INDEX_PATTERN.replace('-*', '')}-001`;
await esClient.indices.delete({ index }).catch(() => {
// ignore errors
diff --git a/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.test.ts b/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.test.ts
index a1b71a9c4f04f..8d274a30ca3c9 100644
--- a/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.test.ts
+++ b/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.test.ts
@@ -23,6 +23,7 @@ import type {
import { ProductFeatureKey } from '@kbn/security-solution-features/keys';
import { httpServiceMock } from '@kbn/core-http-server-mocks';
import type {
+ AuthzEnabled,
KibanaRequest,
LifecycleResponseFactory,
OnPostAuthHandler,
@@ -181,11 +182,6 @@ describe('ProductFeaturesService', () => {
lastRegisteredFn = fn;
});
- const getReq = (tags: string[] = []) =>
- ({
- route: { options: { tags } },
- url: { pathname: '', search: '' },
- } as unknown as KibanaRequest);
const res = { notFound: jest.fn() } as unknown as LifecycleResponseFactory;
const toolkit = httpServiceMock.createOnPostAuthToolkit();
@@ -204,93 +200,281 @@ describe('ProductFeaturesService', () => {
expect(mockHttpSetup.registerOnPostAuth).toHaveBeenCalledTimes(1);
});
- it('should authorize when no tag matches', async () => {
- const experimentalFeatures = {} as ExperimentalFeatures;
- const productFeaturesService = new ProductFeaturesService(
- loggerMock.create(),
- experimentalFeatures
- );
- productFeaturesService.registerApiAccessControl(mockHttpSetup);
-
- await lastRegisteredFn(getReq(['access:something', 'access:securitySolution']), res, toolkit);
-
- expect(MockedProductFeatures.mock.instances[0].isActionRegistered).not.toHaveBeenCalled();
- expect(res.notFound).not.toHaveBeenCalled();
- expect(toolkit.next).toHaveBeenCalledTimes(1);
- });
-
- it('should check when tag matches and return not found when not action registered', async () => {
- const experimentalFeatures = {} as ExperimentalFeatures;
- const productFeaturesService = new ProductFeaturesService(
- loggerMock.create(),
- experimentalFeatures
- );
- productFeaturesService.registerApiAccessControl(mockHttpSetup);
-
- (MockedProductFeatures.mock.instances[0].isActionRegistered as jest.Mock).mockReturnValueOnce(
- false
- );
- await lastRegisteredFn(getReq(['access:securitySolution-foo']), res, toolkit);
-
- expect(MockedProductFeatures.mock.instances[0].isActionRegistered).toHaveBeenCalledWith(
- 'api:securitySolution-foo'
- );
- expect(res.notFound).toHaveBeenCalledTimes(1);
- expect(toolkit.next).not.toHaveBeenCalled();
- });
-
- it('should check when tag matches and continue when action registered', async () => {
- const experimentalFeatures = {} as ExperimentalFeatures;
- const productFeaturesService = new ProductFeaturesService(
- loggerMock.create(),
- experimentalFeatures
- );
- productFeaturesService.registerApiAccessControl(mockHttpSetup);
-
- (MockedProductFeatures.mock.instances[0].isActionRegistered as jest.Mock).mockReturnValueOnce(
- true
- );
- await lastRegisteredFn(getReq(['access:securitySolution-foo']), res, toolkit);
-
- expect(MockedProductFeatures.mock.instances[0].isActionRegistered).toHaveBeenCalledWith(
- 'api:securitySolution-foo'
- );
- expect(res.notFound).not.toHaveBeenCalled();
- expect(toolkit.next).toHaveBeenCalledTimes(1);
- });
-
- it('should check when productFeature tag when it matches and return not found when not enabled', async () => {
- const experimentalFeatures = {} as ExperimentalFeatures;
- const productFeaturesService = new ProductFeaturesService(
- loggerMock.create(),
- experimentalFeatures
- );
- productFeaturesService.registerApiAccessControl(mockHttpSetup);
-
- productFeaturesService.isEnabled = jest.fn().mockReturnValueOnce(false);
-
- await lastRegisteredFn(getReq(['securitySolutionProductFeature:foo']), res, toolkit);
-
- expect(productFeaturesService.isEnabled).toHaveBeenCalledWith('foo');
- expect(res.notFound).toHaveBeenCalledTimes(1);
- expect(toolkit.next).not.toHaveBeenCalled();
+ describe('when using productFeature tag', () => {
+ const getReq = (tags: string[] = []) =>
+ ({
+ route: { options: { tags } },
+ url: { pathname: '', search: '' },
+ } as unknown as KibanaRequest);
+
+ it('should check when productFeature tag when it matches and return not found when not enabled', async () => {
+ const experimentalFeatures = {} as ExperimentalFeatures;
+ const productFeaturesService = new ProductFeaturesService(
+ loggerMock.create(),
+ experimentalFeatures
+ );
+ productFeaturesService.registerApiAccessControl(mockHttpSetup);
+
+ productFeaturesService.isEnabled = jest.fn().mockReturnValueOnce(false);
+
+ await lastRegisteredFn(getReq(['securitySolutionProductFeature:foo']), res, toolkit);
+
+ expect(productFeaturesService.isEnabled).toHaveBeenCalledWith('foo');
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+
+ it('should check when productFeature tag when it matches and continue when enabled', async () => {
+ const experimentalFeatures = {} as ExperimentalFeatures;
+ const productFeaturesService = new ProductFeaturesService(
+ loggerMock.create(),
+ experimentalFeatures
+ );
+ productFeaturesService.registerApiAccessControl(mockHttpSetup);
+
+ productFeaturesService.isEnabled = jest.fn().mockReturnValueOnce(true);
+
+ await lastRegisteredFn(getReq(['securitySolutionProductFeature:foo']), res, toolkit);
+
+ expect(productFeaturesService.isEnabled).toHaveBeenCalledWith('foo');
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
});
- it('should check when productFeature tag when it matches and continue when enabled', async () => {
- const experimentalFeatures = {} as ExperimentalFeatures;
- const productFeaturesService = new ProductFeaturesService(
- loggerMock.create(),
- experimentalFeatures
- );
- productFeaturesService.registerApiAccessControl(mockHttpSetup);
-
- productFeaturesService.isEnabled = jest.fn().mockReturnValueOnce(true);
-
- await lastRegisteredFn(getReq(['securitySolutionProductFeature:foo']), res, toolkit);
-
- expect(productFeaturesService.isEnabled).toHaveBeenCalledWith('foo');
- expect(res.notFound).not.toHaveBeenCalled();
- expect(toolkit.next).toHaveBeenCalledTimes(1);
+ // Documentation: https://docs.elastic.dev/kibana-dev-docs/key-concepts/security-api-authorization
+ describe('when using authorization', () => {
+ let productFeaturesService: ProductFeaturesService;
+ let mockIsActionRegistered: jest.Mock;
+
+ beforeEach(() => {
+ const experimentalFeatures = {} as ExperimentalFeatures;
+ productFeaturesService = new ProductFeaturesService(
+ loggerMock.create(),
+ experimentalFeatures
+ );
+ productFeaturesService.registerApiAccessControl(mockHttpSetup);
+ mockIsActionRegistered = MockedProductFeatures.mock.instances[0]
+ .isActionRegistered as jest.Mock;
+ });
+
+ describe('when using access tag', () => {
+ const getReq = (tags: string[] = []) =>
+ ({
+ route: { options: { tags } },
+ url: { pathname: '', search: '' },
+ } as unknown as KibanaRequest);
+
+ it('should authorize when no tag matches', async () => {
+ await lastRegisteredFn(
+ getReq(['access:something', 'access:securitySolution']),
+ res,
+ toolkit
+ );
+
+ expect(mockIsActionRegistered).not.toHaveBeenCalled();
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+
+ it('should check when tag matches and return not found when not action registered', async () => {
+ mockIsActionRegistered.mockReturnValueOnce(false);
+ await lastRegisteredFn(getReq(['access:securitySolution-foo']), res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-foo');
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+
+ it('should check when tag matches and continue when action registered', async () => {
+ mockIsActionRegistered.mockReturnValueOnce(true);
+ await lastRegisteredFn(getReq(['access:securitySolution-foo']), res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-foo');
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+ });
+
+ describe('when using security authz', () => {
+ beforeEach(() => {
+ mockIsActionRegistered.mockImplementation((action: string) => action.includes('enabled'));
+ });
+
+ const getReq = (requiredPrivileges?: AuthzEnabled['requiredPrivileges']) =>
+ ({
+ route: { options: { security: { authz: { requiredPrivileges } } } },
+ url: { pathname: '', search: '' },
+ } as unknown as KibanaRequest);
+
+ it('should authorize when no privilege matches', async () => {
+ await lastRegisteredFn(getReq(['something', 'securitySolution']), res, toolkit);
+
+ expect(mockIsActionRegistered).not.toHaveBeenCalled();
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+
+ it('should check when privilege matches and return not found when not action registered', async () => {
+ await lastRegisteredFn(getReq(['securitySolution-disabled']), res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled');
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+
+ it('should check when privilege matches and continue when action registered', async () => {
+ mockIsActionRegistered.mockReturnValueOnce(true);
+ await lastRegisteredFn(getReq(['securitySolution-enabled']), res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled');
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+
+ it('should restrict access when one action is not registered', async () => {
+ mockIsActionRegistered.mockReturnValueOnce(true);
+ await lastRegisteredFn(
+ getReq([
+ 'securitySolution-enabled',
+ 'securitySolution-disabled',
+ 'securitySolution-enabled2',
+ ]),
+ res,
+ toolkit
+ );
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(2);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled');
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled');
+
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+
+ describe('when using nested requiredPrivileges', () => {
+ describe('when using allRequired', () => {
+ it('should allow access when all actions are registered', async () => {
+ const req = getReq([
+ {
+ allRequired: [
+ 'securitySolution-enabled',
+ 'securitySolution-enabled2',
+ 'securitySolution-enabled3',
+ ],
+ },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(3);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled');
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled2');
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled3');
+
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+
+ it('should restrict access if one action is not registered', async () => {
+ const req = getReq([
+ {
+ allRequired: [
+ 'securitySolution-enabled',
+ 'securitySolution-disabled',
+ 'securitySolution-notCalled',
+ ],
+ },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(2);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled');
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled');
+
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+
+ it('should allow only based on security privileges and ignore non-security', async () => {
+ const req = getReq([
+ { allRequired: ['notSecurityPrivilege', 'securitySolution-enabled'] },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(1);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled');
+
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+
+ it('should restrict only based on security privileges and ignore non-security', async () => {
+ const req = getReq([
+ { allRequired: ['notSecurityPrivilege', 'securitySolution-disabled'] },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(1);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled');
+
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+ });
+
+ describe('when using anyRequired', () => {
+ it('should allow access when one action is registered', async () => {
+ const req = getReq([
+ {
+ anyRequired: [
+ 'securitySolution-disabled',
+ 'securitySolution-enabled',
+ 'securitySolution-notCalled',
+ ],
+ },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(2);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled');
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-enabled');
+
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+
+ it('should restrict access when no action is registered', async () => {
+ const req = getReq([
+ {
+ anyRequired: ['securitySolution-disabled', 'securitySolution-disabled2'],
+ },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).toHaveBeenCalledTimes(2);
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled');
+ expect(mockIsActionRegistered).toHaveBeenCalledWith('api:securitySolution-disabled2');
+
+ expect(res.notFound).toHaveBeenCalledTimes(1);
+ expect(toolkit.next).not.toHaveBeenCalled();
+ });
+
+ it('should restrict only based on security privileges and allow when non-security privilege is present', async () => {
+ const req = getReq([
+ {
+ anyRequired: ['notSecurityPrivilege', 'securitySolution-disabled'],
+ },
+ ]);
+ await lastRegisteredFn(req, res, toolkit);
+
+ expect(mockIsActionRegistered).not.toHaveBeenCalled();
+
+ expect(res.notFound).not.toHaveBeenCalled();
+ expect(toolkit.next).toHaveBeenCalledTimes(1);
+ });
+ });
+ });
+ });
});
});
});
diff --git a/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.ts b/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.ts
index 29ef513b40bb3..86928ff905545 100644
--- a/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.ts
+++ b/x-pack/plugins/security_solution/server/lib/product_features_service/product_features_service.ts
@@ -11,7 +11,7 @@
* 2.0.
*/
-import type { HttpServiceSetup, Logger } from '@kbn/core/server';
+import type { AuthzEnabled, HttpServiceSetup, Logger, RouteAuthz } from '@kbn/core/server';
import { hiddenTypes as filesSavedObjectTypes } from '@kbn/files-plugin/server/saved_objects';
import type { FeaturesPluginSetup } from '@kbn/features-plugin/server';
import type { ProductFeatureKeyType } from '@kbn/security-solution-features';
@@ -21,6 +21,7 @@ import {
getCasesFeature,
getSecurityFeature,
} from '@kbn/security-solution-features/product_features';
+import type { RecursiveReadonly } from '@kbn/utility-types';
import type { ExperimentalFeatures } from '../../../common';
import { APP_ID } from '../../../common';
import { ProductFeatures } from './product_features';
@@ -28,6 +29,9 @@ import type { ProductFeaturesConfigurator } from './types';
import { securityDefaultSavedObjects } from './security_saved_objects';
import { casesApiTags, casesUiCapabilities } from './cases_privileges';
+// The prefix ("securitySolution-") used by all the Security Solution API action privileges.
+export const API_ACTION_PREFIX = `${APP_ID}-`;
+
export class ProductFeaturesService {
private securityProductFeatures: ProductFeatures;
private casesProductFeatures: ProductFeatures;
@@ -116,8 +120,6 @@ export class ProductFeaturesService {
return this.productFeatures.has(productFeatureKey);
}
- public getApiActionName = (apiPrivilege: string) => `api:${APP_ID}-${apiPrivilege}`;
-
public isActionRegistered(action: string) {
return (
this.securityProductFeatures.isActionRegistered(action) ||
@@ -127,6 +129,9 @@ export class ProductFeaturesService {
);
}
+ public getApiActionName = (apiPrivilege: string) => `api:${API_ACTION_PREFIX}${apiPrivilege}`;
+
+ /** @deprecated Use security.authz.requiredPrivileges instead */
public isApiPrivilegeEnabled(apiPrivilege: string) {
return this.isActionRegistered(this.getApiActionName(apiPrivilege));
}
@@ -135,14 +140,24 @@ export class ProductFeaturesService {
// The `securitySolutionProductFeature:` prefix is used for ProductFeature based control.
// Should be used only by routes that do not need RBAC, only direct productFeature control.
const APP_FEATURE_TAG_PREFIX = 'securitySolutionProductFeature:';
- // The "access:securitySolution-" prefix is used for API action based control.
- // Should be used by routes that need RBAC, extending the `access:` role privilege check from the security plugin.
- // An additional check is performed to ensure the privilege has been registered by the productFeature service,
- // preventing full access (`*`) roles, such as superuser, from bypassing productFeature controls.
+
+ /** @deprecated Use security.authz.requiredPrivileges instead */
const API_ACTION_TAG_PREFIX = `access:${APP_ID}-`;
+ const isAuthzEnabled = (authz?: RecursiveReadonly): authz is AuthzEnabled => {
+ return Boolean((authz as AuthzEnabled)?.requiredPrivileges);
+ };
+
+ /** Returns true only if the API privilege is a security action and is disabled */
+ const isApiPrivilegeSecurityAndDisabled = (apiPrivilege: string): boolean => {
+ if (apiPrivilege.startsWith(API_ACTION_PREFIX)) {
+ return !this.isActionRegistered(`api:${apiPrivilege}`);
+ }
+ return false;
+ };
+
http.registerOnPostAuth((request, response, toolkit) => {
- for (const tag of request.route.options.tags) {
+ for (const tag of request.route.options.tags ?? []) {
let isEnabled = true;
if (tag.startsWith(APP_FEATURE_TAG_PREFIX)) {
isEnabled = this.isEnabled(
@@ -159,6 +174,36 @@ export class ProductFeaturesService {
return response.notFound();
}
}
+
+ // This control ensures the action privileges have been registered by the productFeature service,
+ // preventing full access (`*`) roles, such as superuser, from bypassing productFeature controls.
+ const authz = request.route.options.security?.authz;
+ if (isAuthzEnabled(authz)) {
+ const disabled = authz.requiredPrivileges.some((privilegeEntry) => {
+ if (typeof privilegeEntry === 'object') {
+ if (privilegeEntry.allRequired) {
+ if (privilegeEntry.allRequired.some(isApiPrivilegeSecurityAndDisabled)) {
+ return true;
+ }
+ }
+ if (privilegeEntry.anyRequired) {
+ if (privilegeEntry.anyRequired.every(isApiPrivilegeSecurityAndDisabled)) {
+ return true;
+ }
+ }
+ return false;
+ } else {
+ return isApiPrivilegeSecurityAndDisabled(privilegeEntry);
+ }
+ });
+ if (disabled) {
+ this.logger.warn(
+ `Accessing disabled route "${request.url.pathname}${request.url.search}": responding with 404`
+ );
+ return response.notFound();
+ }
+ }
+
return toolkit.next();
});
}
diff --git a/x-pack/plugins/security_solution/server/lib/telemetry/constants.ts b/x-pack/plugins/security_solution/server/lib/telemetry/constants.ts
index 8e50e4590a72f..50e0e0be47cdd 100644
--- a/x-pack/plugins/security_solution/server/lib/telemetry/constants.ts
+++ b/x-pack/plugins/security_solution/server/lib/telemetry/constants.ts
@@ -27,8 +27,6 @@ export const INSIGHTS_CHANNEL = 'security-insights-v1';
export const TASK_METRICS_CHANNEL = 'task-metrics';
-export const DEFAULT_DIAGNOSTIC_INDEX = '.logs-endpoint.diagnostic.collection-*' as const;
-
export const DEFAULT_ADVANCED_POLICY_CONFIG_SETTINGS = {
linux: {
advanced: {
diff --git a/x-pack/plugins/security_solution/server/lib/telemetry/receiver.ts b/x-pack/plugins/security_solution/server/lib/telemetry/receiver.ts
index 22f85d19c83d8..4d2ff971eeb62 100644
--- a/x-pack/plugins/security_solution/server/lib/telemetry/receiver.ts
+++ b/x-pack/plugins/security_solution/server/lib/telemetry/receiver.ts
@@ -48,6 +48,7 @@ import type {
} from '@kbn/fleet-plugin/server';
import type { ExceptionListClient } from '@kbn/lists-plugin/server';
import moment from 'moment';
+import { DEFAULT_DIAGNOSTIC_INDEX_PATTERN } from '../../../common/endpoint/constants';
import type { ExperimentalFeatures } from '../../../common';
import type { EndpointAppContextService } from '../../endpoint/endpoint_app_context_services';
import {
@@ -85,7 +86,6 @@ import type {
import { telemetryConfiguration } from './configuration';
import { ENDPOINT_METRICS_INDEX } from '../../../common/constants';
import { PREBUILT_RULES_PACKAGE_NAME } from '../../../common/detection_engine/constants';
-import { DEFAULT_DIAGNOSTIC_INDEX } from './constants';
import type { TelemetryLogger } from './telemetry_logger';
export interface ITelemetryReceiver {
@@ -546,7 +546,7 @@ export class TelemetryReceiver implements ITelemetryReceiver {
to: executeTo,
} as LogMeta);
- let pitId = await this.openPointInTime(DEFAULT_DIAGNOSTIC_INDEX);
+ let pitId = await this.openPointInTime(DEFAULT_DIAGNOSTIC_INDEX_PATTERN);
let fetchMore = true;
let searchAfter: SortResults | undefined;
diff --git a/x-pack/plugins/security_solution/server/lib/telemetry/tasks/timelines_diagnostic.ts b/x-pack/plugins/security_solution/server/lib/telemetry/tasks/timelines_diagnostic.ts
index 35f5abeac10af..ec401a093c348 100644
--- a/x-pack/plugins/security_solution/server/lib/telemetry/tasks/timelines_diagnostic.ts
+++ b/x-pack/plugins/security_solution/server/lib/telemetry/tasks/timelines_diagnostic.ts
@@ -6,11 +6,12 @@
*/
import type { Logger } from '@kbn/core/server';
+import { DEFAULT_DIAGNOSTIC_INDEX_PATTERN } from '../../../../common/endpoint/constants';
import type { ITelemetryEventsSender } from '../sender';
import type { ITelemetryReceiver } from '../receiver';
import type { TaskExecutionPeriod } from '../task';
import type { ITaskMetricsService } from '../task_metrics.types';
-import { DEFAULT_DIAGNOSTIC_INDEX, TELEMETRY_CHANNEL_TIMELINE } from '../constants';
+import { TELEMETRY_CHANNEL_TIMELINE } from '../constants';
import { ranges, TelemetryTimelineFetcher, newTelemetryLogger } from '../helpers';
export function createTelemetryDiagnosticTimelineTaskConfig() {
@@ -43,7 +44,7 @@ export function createTelemetryDiagnosticTimelineTaskConfig() {
const { rangeFrom, rangeTo } = ranges(taskExecutionPeriod);
const alerts = await receiver.fetchTimelineAlerts(
- DEFAULT_DIAGNOSTIC_INDEX,
+ DEFAULT_DIAGNOSTIC_INDEX_PATTERN,
rangeFrom,
rangeTo
);
diff --git a/x-pack/plugins/task_manager/server/lib/create_managed_configuration.test.ts b/x-pack/plugins/task_manager/server/lib/create_managed_configuration.test.ts
index 5e0a5ed4f2e67..1da1bb11d1c5d 100644
--- a/x-pack/plugins/task_manager/server/lib/create_managed_configuration.test.ts
+++ b/x-pack/plugins/task_manager/server/lib/create_managed_configuration.test.ts
@@ -185,6 +185,17 @@ describe('createManagedConfiguration()', () => {
expect(subscription).toHaveBeenNthCalledWith(2, 8);
});
+ test('should decrease configuration at the next interval when a 500 error is emitted', async () => {
+ const { subscription, errors$ } = setupScenario(10);
+ errors$.next(SavedObjectsErrorHelpers.decorateGeneralError(new Error('a'), 'b'));
+ clock.tick(ADJUST_THROUGHPUT_INTERVAL - 1);
+ expect(subscription).toHaveBeenCalledTimes(1);
+ expect(subscription).toHaveBeenNthCalledWith(1, 10);
+ clock.tick(1);
+ expect(subscription).toHaveBeenCalledTimes(2);
+ expect(subscription).toHaveBeenNthCalledWith(2, 8);
+ });
+
test('should decrease configuration at the next interval when a 503 error is emitted', async () => {
const { subscription, errors$ } = setupScenario(10);
errors$.next(SavedObjectsErrorHelpers.createGenericNotFoundEsUnavailableError('a', 'b'));
@@ -247,6 +258,17 @@ describe('createManagedConfiguration()', () => {
expect(subscription).toHaveBeenNthCalledWith(2, 8);
});
+ test('should decrease configuration at the next interval when an msearch 500 error is emitted', async () => {
+ const { subscription, errors$ } = setupScenario(10);
+ errors$.next(new MsearchError(500));
+ clock.tick(ADJUST_THROUGHPUT_INTERVAL - 1);
+ expect(subscription).toHaveBeenCalledTimes(1);
+ expect(subscription).toHaveBeenNthCalledWith(1, 10);
+ clock.tick(1);
+ expect(subscription).toHaveBeenCalledTimes(2);
+ expect(subscription).toHaveBeenNthCalledWith(2, 8);
+ });
+
test('should decrease configuration at the next interval when an msearch 503 error is emitted', async () => {
const { subscription, errors$ } = setupScenario(10);
errors$.next(new MsearchError(503));
@@ -338,6 +360,16 @@ describe('createManagedConfiguration()', () => {
expect(subscription).toHaveBeenNthCalledWith(2, 120);
});
+ test('should increase configuration at the next interval when a 500 error is emitted', async () => {
+ const { subscription, errors$ } = setupScenario(100);
+ errors$.next(SavedObjectsErrorHelpers.decorateGeneralError(new Error('a'), 'b'));
+ clock.tick(ADJUST_THROUGHPUT_INTERVAL - 1);
+ expect(subscription).toHaveBeenCalledTimes(1);
+ clock.tick(1);
+ expect(subscription).toHaveBeenCalledTimes(2);
+ expect(subscription).toHaveBeenNthCalledWith(2, 120);
+ });
+
test('should increase configuration at the next interval when a 503 error is emitted', async () => {
const { subscription, errors$ } = setupScenario(100);
errors$.next(SavedObjectsErrorHelpers.createGenericNotFoundEsUnavailableError('a', 'b'));
diff --git a/x-pack/plugins/task_manager/server/lib/create_managed_configuration.ts b/x-pack/plugins/task_manager/server/lib/create_managed_configuration.ts
index 8a76029efb8eb..d13c2511a2a2b 100644
--- a/x-pack/plugins/task_manager/server/lib/create_managed_configuration.ts
+++ b/x-pack/plugins/task_manager/server/lib/create_managed_configuration.ts
@@ -165,8 +165,10 @@ function countErrors(errors$: Observable, countInterval: number): Observa
(e) =>
SavedObjectsErrorHelpers.isTooManyRequestsError(e) ||
SavedObjectsErrorHelpers.isEsUnavailableError(e) ||
+ SavedObjectsErrorHelpers.isGeneralError(e) ||
isEsCannotExecuteScriptError(e) ||
getMsearchStatusCode(e) === 429 ||
+ getMsearchStatusCode(e) === 500 ||
getMsearchStatusCode(e) === 503
)
)
diff --git a/x-pack/test/accessibility/apps/group2/ml_memory_usage.ts b/x-pack/test/accessibility/apps/group2/ml_memory_usage.ts
new file mode 100644
index 0000000000000..363aa2bab1197
--- /dev/null
+++ b/x-pack/test/accessibility/apps/group2/ml_memory_usage.ts
@@ -0,0 +1,55 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import { FtrProviderContext } from '../../ftr_provider_context';
+
+export default function ({ getService }: FtrProviderContext) {
+ const a11y = getService('a11y');
+ const ml = getService('ml');
+
+ const jobId = 'sample_job';
+
+ describe('machine learning memory usage page Accessibility', function () {
+ before(async () => {
+ await ml.securityCommon.createMlRoles();
+ await ml.securityCommon.createMlUsers();
+ await ml.securityUI.loginAsMlPowerUser();
+
+ const jobConfig = ml.commonConfig.getADFqSingleMetricJobConfig(jobId);
+ await ml.api.createAnomalyDetectionJob(jobConfig);
+ await ml.api.openAnomalyDetectionJob(jobId);
+
+ await ml.navigation.navigateToMl();
+ await ml.navigation.navigateToMemoryUsage();
+ });
+
+ after(async () => {
+ await ml.securityCommon.cleanMlUsers();
+ await ml.securityCommon.cleanMlRoles();
+
+ await ml.api.closeAnomalyDetectionJob(jobId);
+ await ml.api.cleanMlIndices();
+ });
+
+ it('memory usage - nodes tab - page', async () => {
+ await a11y.testAppSnapshot();
+ });
+
+ it('memory usage - nodes tab - node details and node memory usage', async () => {
+ await ml.memoryUsage.expandRow();
+ await a11y.testAppSnapshot();
+
+ await ml.memoryUsage.selectNodeExpandedRowTab('mlNodesOverviewPanelMemoryTab');
+ await a11y.testAppSnapshot();
+ });
+
+ it('memory usage - memory usage tab - page', async () => {
+ await ml.memoryUsage.selectTab('memory-usage');
+ await a11y.testAppSnapshot();
+ });
+ });
+}
diff --git a/x-pack/test/alerting_api_integration/common/plugins/alerts/server/rule_types.ts b/x-pack/test/alerting_api_integration/common/plugins/alerts/server/rule_types.ts
index 0700cba718324..6c16c694bc9e9 100644
--- a/x-pack/test/alerting_api_integration/common/plugins/alerts/server/rule_types.ts
+++ b/x-pack/test/alerting_api_integration/common/plugins/alerts/server/rule_types.ts
@@ -17,7 +17,6 @@ import {
RuleTypeState,
RuleTypeParams,
} from '@kbn/alerting-plugin/server';
-import { AlertConsumers } from '@kbn/rule-data-utils';
import { ES_TEST_INDEX_NAME } from '@kbn/alerting-api-integration-helpers';
import { FixtureStartDeps, FixtureSetupDeps } from './plugin';
@@ -884,33 +883,14 @@ function getCancellableRuleType() {
return result;
}
-function getAlwaysFiringAlertAsDataRuleType(
- logger: Logger,
- { ruleRegistry }: Pick
-) {
+function getAlwaysFiringAlertAsDataRuleType() {
const paramsSchema = schema.object({
index: schema.string(),
reference: schema.string(),
});
+ type ParamsType = TypeOf;
- const ruleDataClient = ruleRegistry.ruleDataService.initializeIndex({
- feature: AlertConsumers.OBSERVABILITY,
- registrationContext: 'observability.test.alerts',
- dataset: ruleRegistry.dataset.alerts,
- componentTemplateRefs: [],
- componentTemplates: [
- {
- name: 'mappings',
- },
- ],
- });
-
- const createLifecycleRuleType = ruleRegistry.createLifecycleRuleTypeFactory({
- logger,
- ruleDataClient,
- });
-
- return createLifecycleRuleType({
+ const result: RuleType = {
id: 'test.always-firing-alert-as-data',
name: 'Test: Always Firing Alert As Data',
actionGroups: [{ id: 'default', name: 'Default' }],
@@ -926,19 +906,8 @@ function getAlwaysFiringAlertAsDataRuleType(
const { services, params, state, spaceId, namespace, rule } = ruleExecutorOptions;
const ruleInfo = { spaceId, namespace, ...rule };
- services
- .alertWithLifecycle({
- id: '1',
- fields: {},
- })
- .scheduleActions('default');
-
- services
- .alertWithLifecycle({
- id: '2',
- fields: {},
- })
- .scheduleActions('default');
+ services.alertsClient?.report({ id: '1', actionGroup: 'default' });
+ services.alertsClient?.report({ id: '2', actionGroup: 'default' });
await services.scopedClusterClient.asCurrentUser.index({
index: params.index,
@@ -960,8 +929,10 @@ function getAlwaysFiringAlertAsDataRuleType(
fieldMap: {},
},
useLegacyAlerts: true,
+ shouldWrite: true,
},
- });
+ };
+ return result;
}
function getWaitingRuleType(logger: Logger) {
@@ -1393,7 +1364,7 @@ export function defineRuleTypes(
alerting.registerType(getCancellableRuleType());
alerting.registerType(getPatternSuccessOrFailureRuleType());
alerting.registerType(getExceedsAlertLimitRuleType());
- alerting.registerType(getAlwaysFiringAlertAsDataRuleType(logger, { ruleRegistry }));
+ alerting.registerType(getAlwaysFiringAlertAsDataRuleType());
alerting.registerType(getPatternFiringAutoRecoverFalseRuleType());
alerting.registerType(getPatternFiringAlertsAsDataRuleType());
alerting.registerType(getWaitingRuleType(logger));
diff --git a/x-pack/test/alerting_api_integration/common/plugins/alerts/tsconfig.json b/x-pack/test/alerting_api_integration/common/plugins/alerts/tsconfig.json
index 9088008908f1b..e7fe45ad6fe11 100644
--- a/x-pack/test/alerting_api_integration/common/plugins/alerts/tsconfig.json
+++ b/x-pack/test/alerting_api_integration/common/plugins/alerts/tsconfig.json
@@ -24,7 +24,6 @@
"@kbn/notifications-plugin",
"@kbn/core-saved-objects-server",
"@kbn/logging",
- "@kbn/rule-data-utils",
"@kbn/alerting-api-integration-helpers",
],
"exclude": [
diff --git a/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/backfill/api_key.ts b/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/backfill/api_key.ts
index 46a92d176bab0..cf818de0e4fab 100644
--- a/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/backfill/api_key.ts
+++ b/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/backfill/api_key.ts
@@ -252,6 +252,17 @@ export default function apiKeyBackfillTests({ getService }: FtrProviderContext)
expect(e?.event?.outcome).to.eql('success');
}
+ // wait for all the ad hoc run SO to be deleted
+ await retry.try(async () => {
+ try {
+ // throws when not found
+ await getAdHocRunSO(backfillId);
+ throw new Error('should have thrown');
+ } catch (e) {
+ expect(e.message).not.to.eql('should have thrown');
+ }
+ });
+
// invoke the invalidate task
await runInvalidateTask();
diff --git a/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack.ts b/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack.ts
index 8157c71aef3b8..2fe1aceb60132 100644
--- a/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack.ts
+++ b/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack.ts
@@ -40,6 +40,7 @@ export default function bulkUntrackTests({ getService }: FtrProviderContext) {
match_all: {},
},
conflicts: 'proceed',
+ ignore_unavailable: true,
});
await objectRemover.removeAll();
});
diff --git a/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack_by_query.ts b/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack_by_query.ts
index c7062bd478911..794cb73677730 100644
--- a/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack_by_query.ts
+++ b/x-pack/test/alerting_api_integration/security_and_spaces/group1/tests/alerting/bulk_untrack_by_query.ts
@@ -31,6 +31,7 @@ export default function bulkUntrackByQueryTests({ getService }: FtrProviderConte
match_all: {},
},
conflicts: 'proceed',
+ ignore_unavailable: true,
});
await objectRemover.removeAll();
});
diff --git a/x-pack/test/alerting_api_integration/security_and_spaces/group4/tests/alerting/alerts.ts b/x-pack/test/alerting_api_integration/security_and_spaces/group4/tests/alerting/alerts.ts
index 7e1f824a50b0c..c3cc9f410b203 100644
--- a/x-pack/test/alerting_api_integration/security_and_spaces/group4/tests/alerting/alerts.ts
+++ b/x-pack/test/alerting_api_integration/security_and_spaces/group4/tests/alerting/alerts.ts
@@ -51,7 +51,11 @@ export default function alertTests({ getService }: FtrProviderContext) {
after(async () => {
await esTestIndexTool.destroy();
await es.indices.delete({ index: authorizationIndex });
- await es.deleteByQuery({ index: alertAsDataIndex, query: { match_all: {} } });
+ await es.deleteByQuery({
+ index: alertAsDataIndex,
+ query: { match_all: {} },
+ ignore_unavailable: true,
+ });
});
for (const scenario of UserAtSpaceScenarios) {
@@ -1493,6 +1497,10 @@ instanceStateValue: true
_index: '.internal.alerts-observability.test.alerts.alerts-default-000001',
kibana: {
alert: {
+ action_group: 'default',
+ flapping_history: expectExpect.any(Array),
+ maintenance_window_ids: [],
+ severity_improving: false,
rule: {
parameters: {
index: '.kibana-alerting-test-data',
@@ -1500,7 +1508,10 @@ instanceStateValue: true
},
category: 'Test: Always Firing Alert As Data',
consumer: 'alertsFixture',
- execution: { uuid: expectExpect.any(String) },
+ execution: {
+ uuid: expectExpect.any(String),
+ timestamp: expectExpect.any(String),
+ },
name: 'abc',
producer: 'alertsFixture',
revision: 0,
@@ -1530,6 +1541,10 @@ instanceStateValue: true
_index: '.internal.alerts-observability.test.alerts.alerts-default-000001',
kibana: {
alert: {
+ action_group: 'default',
+ flapping_history: expectExpect.any(Array),
+ maintenance_window_ids: [],
+ severity_improving: false,
rule: {
parameters: {
index: '.kibana-alerting-test-data',
@@ -1537,7 +1552,10 @@ instanceStateValue: true
},
category: 'Test: Always Firing Alert As Data',
consumer: 'alertsFixture',
- execution: { uuid: expectExpect.any(String) },
+ execution: {
+ timestamp: expectExpect.any(String),
+ uuid: expectExpect.any(String),
+ },
name: 'abc',
producer: 'alertsFixture',
revision: 0,
@@ -1583,6 +1601,10 @@ instanceStateValue: true
_index: '.internal.alerts-observability.test.alerts.alerts-default-000001',
kibana: {
alert: {
+ action_group: 'default',
+ flapping_history: expectExpect.any(Array),
+ maintenance_window_ids: [],
+ previous_action_group: 'default',
rule: {
parameters: {
index: '.kibana-alerting-test-data',
@@ -1590,7 +1612,10 @@ instanceStateValue: true
},
category: 'Test: Always Firing Alert As Data',
consumer: 'alertsFixture',
- execution: { uuid: expectExpect.any(String) },
+ execution: {
+ timestamp: expectExpect.any(String),
+ uuid: expectExpect.any(String),
+ },
name: 'abc',
producer: 'alertsFixture',
revision: 0,
@@ -1620,6 +1645,10 @@ instanceStateValue: true
_index: '.internal.alerts-observability.test.alerts.alerts-default-000001',
kibana: {
alert: {
+ action_group: 'default',
+ flapping_history: expectExpect.any(Array),
+ maintenance_window_ids: [],
+ previous_action_group: 'default',
rule: {
parameters: {
index: '.kibana-alerting-test-data',
@@ -1627,7 +1656,10 @@ instanceStateValue: true
},
category: 'Test: Always Firing Alert As Data',
consumer: 'alertsFixture',
- execution: { uuid: expectExpect.any(String) },
+ execution: {
+ timestamp: expectExpect.any(String),
+ uuid: expectExpect.any(String),
+ },
name: 'abc',
producer: 'alertsFixture',
revision: 0,
@@ -1721,6 +1753,10 @@ instanceStateValue: true
_index: '.internal.alerts-observability.test.alerts.alerts-default-000001',
kibana: {
alert: {
+ action_group: 'default',
+ flapping_history: expectExpect.any(Array),
+ maintenance_window_ids: [],
+ severity_improving: false,
rule: {
parameters: {
index: '.kibana-alerting-test-data',
@@ -1728,7 +1764,10 @@ instanceStateValue: true
},
category: 'Test: Always Firing Alert As Data',
consumer: 'alertsFixture',
- execution: { uuid: expectExpect.any(String) },
+ execution: {
+ uuid: expectExpect.any(String),
+ timestamp: expectExpect.any(String),
+ },
name: 'abc',
producer: 'alertsFixture',
revision: 0,
@@ -1758,6 +1797,10 @@ instanceStateValue: true
_index: '.internal.alerts-observability.test.alerts.alerts-default-000001',
kibana: {
alert: {
+ action_group: 'default',
+ flapping_history: expectExpect.any(Array),
+ maintenance_window_ids: [],
+ severity_improving: false,
rule: {
parameters: {
index: '.kibana-alerting-test-data',
@@ -1765,7 +1808,10 @@ instanceStateValue: true
},
category: 'Test: Always Firing Alert As Data',
consumer: 'alertsFixture',
- execution: { uuid: expectExpect.any(String) },
+ execution: {
+ uuid: expectExpect.any(String),
+ timestamp: expectExpect.any(String),
+ },
name: 'abc',
producer: 'alertsFixture',
revision: 0,
@@ -1901,7 +1947,7 @@ instanceStateValue: true
*/
const response = await alertUtils.createAlwaysFiringSystemAction({
reference,
- overwrites: { schedule: { interval: '1s' } },
+ overwrites: { schedule: { interval: '1m' } },
});
expect(response.status).to.eql(200);
diff --git a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group1/disable.ts b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group1/disable.ts
index 87d6f7e8da59f..01fa746b65f2a 100644
--- a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group1/disable.ts
+++ b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group1/disable.ts
@@ -43,6 +43,7 @@ export default function createDisableRuleTests({ getService }: FtrProviderContex
match_all: {},
},
conflicts: 'proceed',
+ ignore_unavailable: true,
});
await objectRemover.removeAll();
});
diff --git a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/alerts_as_data/alerts_as_data_alert_delay.ts b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/alerts_as_data/alerts_as_data_alert_delay.ts
index 9665e112facbc..59068ee945ea2 100644
--- a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/alerts_as_data/alerts_as_data_alert_delay.ts
+++ b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/alerts_as_data/alerts_as_data_alert_delay.ts
@@ -34,7 +34,7 @@ import {
ALERT_CONSECUTIVE_MATCHES,
} from '@kbn/rule-data-utils';
import { RuleNotifyWhen } from '@kbn/alerting-plugin/common';
-import { ES_TEST_INDEX_NAME, ESTestIndexTool } from '@kbn/alerting-api-integration-helpers';
+import { ESTestIndexTool } from '@kbn/alerting-api-integration-helpers';
import { FtrProviderContext } from '../../../../../common/ftr_provider_context';
import { Spaces } from '../../../../scenarios';
import {
@@ -79,6 +79,7 @@ export default function createAlertsAsDataAlertDelayInstallResourcesTest({
index: [alertsAsDataIndex, alwaysFiringAlertsAsDataIndex],
query: { match_all: {} },
conflicts: 'proceed',
+ ignore_unavailable: true,
});
});
afterEach(async () => {
@@ -87,6 +88,7 @@ export default function createAlertsAsDataAlertDelayInstallResourcesTest({
index: [alertsAsDataIndex, alwaysFiringAlertsAsDataIndex],
query: { match_all: {} },
conflicts: 'proceed',
+ ignore_unavailable: true,
});
});
after(async () => {
@@ -395,234 +397,6 @@ export default function createAlertsAsDataAlertDelayInstallResourcesTest({
expect(alertDocsRun6.length).to.equal(1);
});
- it('should generate expected events with a alertDelay with AAD (rule registry)', async () => {
- const params = {
- index: ES_TEST_INDEX_NAME,
- reference: 'test',
- };
- const { body: createdAction } = await supertestWithoutAuth
- .post(`${getUrlPrefix(Spaces.space1.id)}/api/actions/connector`)
- .set('kbn-xsrf', 'foo')
- .send({
- name: 'MY action',
- connector_type_id: 'test.noop',
- config: {},
- secrets: {},
- })
- .expect(200);
-
- const response = await supertestWithoutAuth
- .post(`${getUrlPrefix(Spaces.space1.id)}/api/alerting/rule`)
- .set('kbn-xsrf', 'foo')
- .send(
- getTestRuleData({
- rule_type_id: 'test.always-firing-alert-as-data',
- schedule: { interval: '1d' },
- throttle: null,
- notify_when: null,
- params,
- actions: [
- {
- id: createdAction.id,
- group: 'default',
- params: {},
- frequency: {
- summary: false,
- throttle: null,
- notify_when: RuleNotifyWhen.CHANGE,
- },
- },
- ],
- alert_delay: {
- active: 3,
- },
- })
- );
-
- expect(response.status).to.eql(200);
- const ruleId = response.body.id;
- objectRemover.add(Spaces.space1.id, ruleId, 'rule', 'alerting');
-
- // --------------------------
- // RUN 1 - 0 new alerts
- // --------------------------
- let events: IValidatedEvent[] = await waitForEventLogDocs(
- ruleId,
- new Map([['execute', { equal: 1 }]])
- );
- let executeEvent = events[0];
- expect(get(executeEvent, ACTIVE_PATH)).to.be(0);
- expect(get(executeEvent, NEW_PATH)).to.be(0);
- expect(get(executeEvent, RECOVERED_PATH)).to.be(0);
- expect(get(executeEvent, ACTION_PATH)).to.be(0);
- expect(get(executeEvent, DELAYED_PATH)).to.be(2);
-
- // Query for alerts
- const alertDocsRun1 = await queryForAlertDocs(alwaysFiringAlertsAsDataIndex);
-
- // Get alert state from task document
- let state: any = await getTaskState(ruleId);
- expect(state.alertInstances['1'].meta.activeCount).to.equal(1);
- expect(state.alertTypeState.trackedAlerts['1'].activeCount).to.equal(1);
-
- // After the first run, we should have 0 alert docs for the 0 active alerts
- expect(alertDocsRun1.length).to.equal(0);
-
- // --------------------------
- // RUN 2 - 0 new alerts
- // --------------------------
- let runSoon = await supertestWithoutAuth
- .post(`${getUrlPrefix(Spaces.space1.id)}/internal/alerting/rule/${ruleId}/_run_soon`)
- .set('kbn-xsrf', 'foo');
- expect(runSoon.status).to.eql(204);
-
- events = await waitForEventLogDocs(ruleId, new Map([['execute', { equal: 2 }]]));
- executeEvent = events[1];
- expect(get(executeEvent, ACTIVE_PATH)).to.be(0);
- expect(get(executeEvent, NEW_PATH)).to.be(0);
- expect(get(executeEvent, RECOVERED_PATH)).to.be(0);
- expect(get(executeEvent, ACTION_PATH)).to.be(0);
- expect(get(executeEvent, DELAYED_PATH)).to.be(2);
-
- // Query for alerts
- const alertDocsRun2 = await queryForAlertDocs(alwaysFiringAlertsAsDataIndex);
-
- // Get alert state from task document
- state = await getTaskState(ruleId);
- expect(state.alertInstances['1'].meta.activeCount).to.equal(2);
- expect(state.alertTypeState.trackedAlerts['1'].activeCount).to.equal(2);
-
- // After the second run, we should have 0 alert docs for the 0 active alerts
- expect(alertDocsRun2.length).to.equal(0);
-
- // --------------------------
- // RUN 3 - 1 new alert
- // --------------------------
- runSoon = await supertestWithoutAuth
- .post(`${getUrlPrefix(Spaces.space1.id)}/internal/alerting/rule/${ruleId}/_run_soon`)
- .set('kbn-xsrf', 'foo');
- expect(runSoon.status).to.eql(204);
-
- events = await waitForEventLogDocs(ruleId, new Map([['execute', { equal: 3 }]]));
- executeEvent = events[2];
- let executionUuid = get(executeEvent, UUID_PATH);
- // Note: the rule creates 2 alerts but we will only look at one
- expect(get(executeEvent, ACTIVE_PATH)).to.be(2);
- expect(get(executeEvent, NEW_PATH)).to.be(2);
- expect(get(executeEvent, RECOVERED_PATH)).to.be(0);
- expect(get(executeEvent, ACTION_PATH)).to.be(2);
- expect(get(executeEvent, DELAYED_PATH)).to.be(0);
-
- // Query for alerts
- const alertDocsRun3 = await queryForAlertDocs(alwaysFiringAlertsAsDataIndex);
-
- // Get alert state from task document
- state = await getTaskState(ruleId);
- expect(state.alertInstances['1'].meta.activeCount).to.equal(3);
- expect(state.alertTypeState.trackedAlerts['1'].activeCount).to.equal(3);
-
- // After the third run, we should have 2 alert docs for the 2 active alerts but we will only look at one
- expect(alertDocsRun3.length).to.equal(2);
-
- let source: Alert = alertDocsRun3[0]._source!;
-
- // Each doc should have a copy of the rule data
- expect(source[ALERT_RULE_CATEGORY]).to.equal('Test: Always Firing Alert As Data');
- expect(source[ALERT_RULE_CONSUMER]).to.equal('alertsFixture');
- expect(source[ALERT_RULE_NAME]).to.equal('abc');
- expect(source[ALERT_RULE_PRODUCER]).to.equal('alertsFixture');
- expect(source[ALERT_RULE_TAGS]).to.eql(['foo']);
- expect(source[ALERT_RULE_TYPE_ID]).to.equal('test.always-firing-alert-as-data');
- expect(source[ALERT_RULE_UUID]).to.equal(ruleId);
- expect(source[ALERT_RULE_PARAMETERS]).to.eql(params);
- expect(source[SPACE_IDS]).to.eql(['space1']);
- expect(source[ALERT_RULE_EXECUTION_UUID]).to.equal(executionUuid);
- // alert UUID should equal doc id
- expect(source[ALERT_UUID]).to.equal(alertDocsRun3[0]._id);
- // duration should be 0 since this is a new alert
- expect(source[ALERT_DURATION]).to.equal(0);
- // start should be defined
- expect(source[ALERT_START]).to.match(timestampPattern);
- // time_range.gte should be same as start
- expect(source[ALERT_TIME_RANGE]?.gte).to.equal(source[ALERT_START]);
- // timestamp should be defined
- expect(source['@timestamp']).to.match(timestampPattern);
- // status should be active
- expect(source[ALERT_STATUS]).to.equal('active');
- // workflow status should be 'open'
- expect(source[ALERT_WORKFLOW_STATUS]).to.equal('open');
- // event.action should be 'open'
- expect(source[EVENT_ACTION]).to.equal('open');
- // event.kind should be 'signal'
- expect(source[EVENT_KIND]).to.equal('signal');
- // tags should equal rule tags because rule type doesn't set any tags
- expect(source.tags).to.eql(['foo']);
- // alert consecutive matches should match the active count
- expect(source[ALERT_CONSECUTIVE_MATCHES]).to.equal(3);
-
- // --------------------------
- // RUN 4 - 1 active alert
- // --------------------------
- runSoon = await supertestWithoutAuth
- .post(`${getUrlPrefix(Spaces.space1.id)}/internal/alerting/rule/${ruleId}/_run_soon`)
- .set('kbn-xsrf', 'foo');
- expect(runSoon.status).to.eql(204);
-
- events = await waitForEventLogDocs(ruleId, new Map([['execute', { equal: 4 }]]));
- executeEvent = events[3];
- executionUuid = get(executeEvent, UUID_PATH);
- // Note: the rule creates 2 alerts but we will only look at one
- expect(get(executeEvent, ACTIVE_PATH)).to.be(2);
- expect(get(executeEvent, NEW_PATH)).to.be(0);
- expect(get(executeEvent, RECOVERED_PATH)).to.be(0);
- expect(get(executeEvent, ACTION_PATH)).to.be(0);
- expect(get(executeEvent, DELAYED_PATH)).to.be(0);
-
- // Query for alerts
- const alertDocsRun4 = await queryForAlertDocs(alwaysFiringAlertsAsDataIndex);
-
- // Get alert state from task document
- state = await getTaskState(ruleId);
- expect(state.alertInstances['1'].meta.activeCount).to.equal(4);
- expect(state.alertTypeState.trackedAlerts['1'].activeCount).to.equal(4);
-
- // After the fourth run, we should have 2 alert docs for the 2 active alerts but we will only look at one
- expect(alertDocsRun4.length).to.equal(2);
-
- source = alertDocsRun4[0]._source!;
- const run3Source = alertDocsRun3[0]._source!;
-
- // Each doc should have a copy of the rule data
- expect(source[ALERT_RULE_CATEGORY]).to.equal('Test: Always Firing Alert As Data');
- expect(source[ALERT_RULE_CONSUMER]).to.equal('alertsFixture');
- expect(source[ALERT_RULE_NAME]).to.equal('abc');
- expect(source[ALERT_RULE_PRODUCER]).to.equal('alertsFixture');
- expect(source[ALERT_RULE_TAGS]).to.eql(['foo']);
- expect(source[ALERT_RULE_TYPE_ID]).to.equal('test.always-firing-alert-as-data');
- expect(source[ALERT_RULE_UUID]).to.equal(ruleId);
- expect(source[ALERT_RULE_PARAMETERS]).to.eql(params);
- expect(source[SPACE_IDS]).to.eql(['space1']);
- expect(source[ALERT_RULE_EXECUTION_UUID]).to.equal(executionUuid);
- expect(source[ALERT_UUID]).to.equal(run3Source[ALERT_UUID]);
- // start time should be defined and the same as prior run
- expect(source[ALERT_START]).to.match(timestampPattern);
- expect(source[ALERT_START]).to.equal(run3Source[ALERT_START]);
- // timestamp should be defined and not the same as prior run
- expect(source['@timestamp']).to.match(timestampPattern);
- expect(source['@timestamp']).not.to.equal(run3Source['@timestamp']);
- // status should still be active
- expect(source[ALERT_STATUS]).to.equal('active');
- // event.action set to active
- expect(source[EVENT_ACTION]).to.eql('active');
- expect(source.tags).to.eql(['foo']);
- // these values should be the same as previous run
- expect(source[EVENT_KIND]).to.eql(run3Source[EVENT_KIND]);
- expect(source[ALERT_WORKFLOW_STATUS]).to.eql(run3Source[ALERT_WORKFLOW_STATUS]);
- expect(source[ALERT_TIME_RANGE]?.gte).to.equal(run3Source[ALERT_TIME_RANGE]?.gte);
- // alert consecutive matches should match the active count
- expect(source[ALERT_CONSECUTIVE_MATCHES]).to.equal(4);
- });
-
it('should not recover alert if the activeCount did not reach the alertDelay threshold with AAD', async () => {
const { body: createdAction } = await supertestWithoutAuth
.post(`${getUrlPrefix(Spaces.space1.id)}/api/actions/connector`)
diff --git a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/bulk_disable.ts b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/bulk_disable.ts
index e5692e73a15ab..8cf9de5fd3057 100644
--- a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/bulk_disable.ts
+++ b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/group4/bulk_disable.ts
@@ -63,6 +63,7 @@ export default function createDisableRuleTests({ getService }: FtrProviderContex
match_all: {},
},
conflicts: 'proceed',
+ ignore_unavailable: true,
});
await objectRemover.removeAll();
});
diff --git a/x-pack/test/api_integration/apis/synthetics/add_monitor.ts b/x-pack/test/api_integration/apis/synthetics/add_monitor.ts
index 01e5c175ee7d6..aee2e1e2c7212 100644
--- a/x-pack/test/api_integration/apis/synthetics/add_monitor.ts
+++ b/x-pack/test/api_integration/apis/synthetics/add_monitor.ts
@@ -8,7 +8,7 @@ import expect from '@kbn/expect';
import epct from 'expect';
import moment from 'moment/moment';
import { v4 as uuidv4 } from 'uuid';
-import { omit } from 'lodash';
+import { omit, omitBy } from 'lodash';
import {
ConfigKey,
MonitorTypeEnum,
@@ -23,7 +23,10 @@ import { format as formatUrl } from 'url';
import supertest from 'supertest';
import { getServiceApiKeyPrivileges } from '@kbn/synthetics-plugin/server/synthetics_service/get_api_key';
import { syntheticsMonitorType } from '@kbn/synthetics-plugin/common/types/saved_objects';
-import { transformPublicKeys } from '@kbn/synthetics-plugin/server/routes/monitor_cruds/formatters/saved_object_to_monitor';
+import {
+ removeMonitorEmptyValues,
+ transformPublicKeys,
+} from '@kbn/synthetics-plugin/server/routes/monitor_cruds/formatters/saved_object_to_monitor';
import { FtrProviderContext } from '../../ftr_provider_context';
import { getFixtureJson } from './helper/get_fixture_json';
import { SyntheticsMonitorTestService } from './services/synthetics_monitor_test_service';
@@ -61,7 +64,7 @@ export const keyToOmitList = [
];
export const omitMonitorKeys = (monitor: any) => {
- return omit(transformPublicKeys(monitor), keyToOmitList);
+ return omitBy(omit(transformPublicKeys(monitor), keyToOmitList), removeMonitorEmptyValues);
};
export default function ({ getService }: FtrProviderContext) {
diff --git a/x-pack/test/api_integration/apis/synthetics/get_monitor.ts b/x-pack/test/api_integration/apis/synthetics/get_monitor.ts
index 16b42c4dfd0ce..af3f818ab5319 100644
--- a/x-pack/test/api_integration/apis/synthetics/get_monitor.ts
+++ b/x-pack/test/api_integration/apis/synthetics/get_monitor.ts
@@ -242,7 +242,6 @@ export default function ({ getService }: FtrProviderContext) {
revision: 1,
locations: [LOCAL_LOCATION],
name: 'Test HTTP Monitor 044',
- labels: {},
})
);
});
diff --git a/x-pack/test/cloud_security_posture_functional/pages/alerts_flyout.ts b/x-pack/test/cloud_security_posture_functional/pages/alerts_flyout.ts
index 3095f6a663968..9657c0f212f9b 100644
--- a/x-pack/test/cloud_security_posture_functional/pages/alerts_flyout.ts
+++ b/x-pack/test/cloud_security_posture_functional/pages/alerts_flyout.ts
@@ -17,7 +17,8 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) {
const pageObjects = getPageObjects(['common', 'header', 'alerts']);
const alertsPage = pageObjects.alerts;
- describe('Security Alerts Page - Graph visualization', function () {
+ // Failing: See https://github.com/elastic/kibana/issues/198632
+ describe.skip('Security Alerts Page - Graph visualization', function () {
this.tags(['cloud_security_posture_graph_viz']);
before(async () => {
diff --git a/x-pack/test/fleet_api_integration/apis/space_awareness/agent_policies.ts b/x-pack/test/fleet_api_integration/apis/space_awareness/agent_policies.ts
index 037ba332cfefb..3f6a26de52bb6 100644
--- a/x-pack/test/fleet_api_integration/apis/space_awareness/agent_policies.ts
+++ b/x-pack/test/fleet_api_integration/apis/space_awareness/agent_policies.ts
@@ -97,5 +97,21 @@ export default function (providerContext: FtrProviderContext) {
);
});
});
+
+ describe('POST /agent_policies', () => {
+ it('should create fleet-server-policy in the default space', async () => {
+ const res = await apiClient.createAgentPolicy('default', {
+ has_fleet_server: true,
+ });
+ expect(res.item.id).to.eql('fleet-server-policy');
+ });
+
+ it('should create fleet-server-policy in the test space', async () => {
+ const res = await apiClient.createAgentPolicy(TEST_SPACE_1, {
+ has_fleet_server: true,
+ });
+ expect(res.item.id).to.eql(`${TEST_SPACE_1}-fleet-server-policy`);
+ });
+ });
});
}
diff --git a/x-pack/test/functional/apps/ml/short_tests/model_management/model_list.ts b/x-pack/test/functional/apps/ml/short_tests/model_management/model_list.ts
index c828e8da1f3af..7977f17bf5f65 100644
--- a/x-pack/test/functional/apps/ml/short_tests/model_management/model_list.ts
+++ b/x-pack/test/functional/apps/ml/short_tests/model_management/model_list.ts
@@ -416,7 +416,8 @@ export default function ({ getService }: FtrProviderContext) {
it('displays a model without an ingest pipeline and model can be deleted', async () => {
await ml.testExecution.logTestStep('should display the model in the table');
- await ml.trainedModelsTable.filterWithSearchString(modelWithoutPipelineData.modelId, 1);
+ await ml.testExecution.logTestStep('expands the row to show the model details');
+ await ml.trainedModelsTable.ensureRowIsExpanded(modelWithoutPipelineData.modelId);
await ml.testExecution.logTestStep(
'displays expected row values for the model in the table'
diff --git a/x-pack/test/functional/services/ml/memory_usage.ts b/x-pack/test/functional/services/ml/memory_usage.ts
index 76d6259bc57d5..dadb1d10b2b83 100644
--- a/x-pack/test/functional/services/ml/memory_usage.ts
+++ b/x-pack/test/functional/services/ml/memory_usage.ts
@@ -8,6 +8,9 @@
import expect from '@kbn/expect';
import { FtrProviderContext } from '../../ftr_provider_context';
+type NodeExpandedRowTab = 'mlNodesOverviewPanelMemoryTab' | 'mlNodesOverviewPanelDetailsTab';
+type PageTab = 'memory-usage' | 'nodes';
+
export function MachineLearningMemoryUsageProvider({ getService }: FtrProviderContext) {
const testSubjects = getService('testSubjects');
const comboBox = getService('comboBox');
@@ -22,7 +25,7 @@ export function MachineLearningMemoryUsageProvider({ getService }: FtrProviderCo
await testSubjects.existOrFail(`mlNodesOverviewPanel ${tabName}Tab`);
},
- async selectTab(tabName: string) {
+ async selectTab(tabName: PageTab) {
await testSubjects.click(`mlMemoryUsageTab-${tabName}`);
},
@@ -79,7 +82,7 @@ export function MachineLearningMemoryUsageProvider({ getService }: FtrProviderCo
await testSubjects.setValue('mlNodesTableSearchInput', nodeId);
},
- async selectNodeExpandedRowTab(tabName: string) {
+ async selectNodeExpandedRowTab(tabName: NodeExpandedRowTab) {
await testSubjects.click(tabName);
},
diff --git a/x-pack/test/observability_ai_assistant_api_integration/tests/knowledge_base/knowledge_base_user_instructions.spec.ts b/x-pack/test/observability_ai_assistant_api_integration/tests/knowledge_base/knowledge_base_user_instructions.spec.ts
index dc0f991c66ee2..a93c194c85daa 100644
--- a/x-pack/test/observability_ai_assistant_api_integration/tests/knowledge_base/knowledge_base_user_instructions.spec.ts
+++ b/x-pack/test/observability_ai_assistant_api_integration/tests/knowledge_base/knowledge_base_user_instructions.spec.ts
@@ -10,6 +10,7 @@ import { kbnTestConfig } from '@kbn/test';
import { sortBy } from 'lodash';
import { Message, MessageRole } from '@kbn/observability-ai-assistant-plugin/common';
import { CONTEXT_FUNCTION_NAME } from '@kbn/observability-ai-assistant-plugin/server/functions/context';
+import { Instruction } from '@kbn/observability-ai-assistant-plugin/common/types';
import { FtrProviderContext } from '../../common/ftr_provider_context';
import {
clearConversations,
@@ -51,8 +52,7 @@ export default function ApiTest({ getService }: FtrProviderContext) {
await clearConversations(es);
});
- // FLAKY: https://github.com/elastic/kibana/issues/192222
- describe.skip('when creating private and public user instructions', () => {
+ describe('when creating private and public user instructions', () => {
before(async () => {
await clearKnowledgeBase(es);
@@ -75,6 +75,7 @@ export default function ApiTest({ getService }: FtrProviderContext) {
},
].map(async ({ username, isPublic }) => {
const visibility = isPublic ? 'Public' : 'Private';
+
await getScopedApiClientForUsername(username)({
endpoint: 'PUT /internal/observability_ai_assistant/kb/user_instructions',
params: {
@@ -94,9 +95,12 @@ export default function ApiTest({ getService }: FtrProviderContext) {
const res = await observabilityAIAssistantAPIClient.editorUser({
endpoint: 'GET /internal/observability_ai_assistant/kb/user_instructions',
});
+
const instructions = res.body.userInstructions;
- const sortByDocId = (data: any) => sortBy(data, 'doc_id');
+ const sortByDocId = (data: Array) =>
+ sortBy(data, 'doc_id');
+
expect(sortByDocId(instructions)).to.eql(
sortByDocId([
{
@@ -124,7 +128,9 @@ export default function ApiTest({ getService }: FtrProviderContext) {
});
const instructions = res.body.userInstructions;
- const sortByDocId = (data: any) => sortBy(data, 'doc_id');
+ const sortByDocId = (data: Array) =>
+ sortBy(data, 'doc_id');
+
expect(sortByDocId(instructions)).to.eql(
sortByDocId([
{
diff --git a/x-pack/test/plugin_api_integration/test_suites/task_manager/check_registered_task_types.ts b/x-pack/test/plugin_api_integration/test_suites/task_manager/check_registered_task_types.ts
index 55856f3c80402..79bdd3ad7df09 100644
--- a/x-pack/test/plugin_api_integration/test_suites/task_manager/check_registered_task_types.ts
+++ b/x-pack/test/plugin_api_integration/test_suites/task_manager/check_registered_task_types.ts
@@ -81,6 +81,7 @@ export default function ({ getService }: FtrProviderContext) {
'actions:.torq',
'actions:.webhook',
'actions:.xmatters',
+ 'actions:connector_usage_reporting',
'actions_telemetry',
'ad_hoc_run-backfill',
'alerting:.es-query',
diff --git a/x-pack/test/rule_registry/spaces_only/tests/trial/index.ts b/x-pack/test/rule_registry/spaces_only/tests/trial/index.ts
index a8c8421815eec..964139be03bb4 100644
--- a/x-pack/test/rule_registry/spaces_only/tests/trial/index.ts
+++ b/x-pack/test/rule_registry/spaces_only/tests/trial/index.ts
@@ -23,6 +23,5 @@ export default ({ loadTestFile, getService }: FtrProviderContext): void => {
// Trial
loadTestFile(require.resolve('./get_alert_by_id'));
loadTestFile(require.resolve('./update_alert'));
- loadTestFile(require.resolve('./lifecycle_executor'));
});
};
diff --git a/x-pack/test/rule_registry/spaces_only/tests/trial/lifecycle_executor.ts b/x-pack/test/rule_registry/spaces_only/tests/trial/lifecycle_executor.ts
deleted file mode 100644
index 9f6eebedd7e7c..0000000000000
--- a/x-pack/test/rule_registry/spaces_only/tests/trial/lifecycle_executor.ts
+++ /dev/null
@@ -1,275 +0,0 @@
-/*
- * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
- * or more contributor license agreements. Licensed under the Elastic License
- * 2.0; you may not use this file except in compliance with the Elastic License
- * 2.0.
- */
-
-// WARNING: This test running in Function Test Runner is building a live
-// LifecycleRuleExecutor, feeding it some mock data, but letting it write
-// it's various alerts to indices. I suspect it's quite fragile, and I
-// added this comment to fix some fragility in the way the alert factory
-// was built. I suspect it will suffer more such things in the future.
-// I fixed this as a drive-by, but opened an issue to do something later,
-// if needed: https://github.com/elastic/kibana/issues/144557
-
-import { type Subject, ReplaySubject, of } from 'rxjs';
-import type { ElasticsearchClient, Logger, LogMeta } from '@kbn/core/server';
-import sinon from 'sinon';
-import expect from '@kbn/expect';
-import { mappingFromFieldMap } from '@kbn/alerting-plugin/common';
-import {
- AlertConsumers,
- ALERT_REASON,
- ALERT_UUID,
-} from '@kbn/rule-registry-plugin/common/technical_rule_data_field_names';
-import {
- createLifecycleExecutor,
- WrappedLifecycleRuleState,
-} from '@kbn/rule-registry-plugin/server/utils/create_lifecycle_executor';
-import { Dataset, IRuleDataClient, RuleDataService } from '@kbn/rule-registry-plugin/server';
-import { RuleExecutorOptions } from '@kbn/alerting-plugin/server';
-import { getDataStreamAdapter } from '@kbn/alerting-plugin/server/alerts_service/lib/data_stream_adapter';
-import type { FtrProviderContext } from '../../../common/ftr_provider_context';
-import {
- MockRuleParams,
- MockRuleState,
- MockAlertContext,
- MockAlertState,
- MockAllowedActionGroups,
-} from '../../../common/types';
-import { cleanupRegistryIndices, getMockAlertFactory } from '../../../common/lib/helpers';
-
-// eslint-disable-next-line import/no-default-export
-export default function createLifecycleExecutorApiTest({ getService }: FtrProviderContext) {
- const es = getService('es');
- const log = getService('log');
-
- const fakeLogger = (msg: string, meta?: Meta) =>
- meta ? log.debug(msg, meta) : log.debug(msg);
-
- const logger = {
- trace: fakeLogger,
- debug: fakeLogger,
- info: fakeLogger,
- warn: fakeLogger,
- error: fakeLogger,
- fatal: fakeLogger,
- log: sinon.stub(),
- get: sinon.stub(),
- isLevelEnabled: sinon.stub(),
- } as Logger;
-
- const getClusterClient = () => {
- const client = es as ElasticsearchClient;
- return Promise.resolve(client);
- };
-
- const dataStreamAdapter = getDataStreamAdapter({ useDataStreamForAlerts: false });
-
- describe('createLifecycleExecutor', () => {
- let ruleDataClient: IRuleDataClient;
- let pluginStop$: Subject;
- const elasticsearchAndSOAvailability$ = of(true);
-
- before(async () => {
- // First we need to setup the data service. This happens within the
- // Rule Registry plugin as part of the server side setup phase.
- pluginStop$ = new ReplaySubject(1);
-
- const ruleDataService = new RuleDataService({
- getClusterClient,
- logger,
- kibanaVersion: '8.0.0',
- isWriteEnabled: true,
- isWriterCacheEnabled: false,
- disabledRegistrationContexts: [] as string[],
- frameworkAlerts: {
- enabled: () => false,
- getContextInitializationPromise: async () => ({ result: false }),
- },
- pluginStop$,
- dataStreamAdapter,
- elasticsearchAndSOAvailability$,
- });
-
- // This initializes the service. This happens immediately after the creation
- // of the RuleDataService in the setup phase of the Rule Registry plugin
- ruleDataService.initializeService();
-
- // This initializes the index and templates and returns the data client.
- // This happens in each solution plugin before they can register lifecycle
- // executors.
- ruleDataClient = ruleDataService.initializeIndex({
- feature: AlertConsumers.OBSERVABILITY,
- registrationContext: 'observability.test',
- dataset: Dataset.alerts,
- componentTemplateRefs: [],
- componentTemplates: [
- {
- name: 'mappings',
- mappings: mappingFromFieldMap(
- {
- testObject: {
- type: 'object',
- required: false,
- array: false,
- },
- },
- false
- ),
- },
- ],
- });
- });
-
- after(async () => {
- cleanupRegistryIndices(getService, ruleDataClient);
- pluginStop$.next();
- pluginStop$.complete();
- });
-
- it('should work with object fields', async () => {
- const id = 'host-01';
-
- // This creates the function that will wrap the solution's rule executor with the RuleRegistry lifecycle
- const createLifecycleRuleExecutor = createLifecycleExecutor(logger, ruleDataClient);
-
- // This creates the executor that is passed to the Alerting framework.
- const executor = createLifecycleRuleExecutor<
- MockRuleParams,
- MockRuleState,
- MockAlertState,
- MockAlertContext,
- MockAllowedActionGroups
- >(async function (options) {
- const { services, state: previousState } = options;
- const { alertWithLifecycle } = services;
-
- // Fake some state updates
- const state = previousState.testObject
- ? {
- ...previousState,
- testObject: {
- ...previousState.testObject,
- values: [
- ...previousState.testObject.values,
- { name: 'count', value: previousState.testObject.values.length + 1 },
- ],
- },
- }
- : {
- ...previousState,
- testObject: {
- id,
- values: [{ name: 'count', value: 1 }],
- host: {
- name: id,
- },
- },
- };
-
- // This MUST be called by the solutions executor function
- alertWithLifecycle({
- id,
- fields: {
- [ALERT_REASON]: 'Test alert is firing',
- ...state,
- },
- });
-
- // Returns the current state of the alert
- return Promise.resolve({ state });
- });
-
- const ruleId = 'rule-id';
- // Create the options with the minimal amount of values to test the lifecycle executor
- const options = {
- alertId: ruleId,
- spaceId: 'default',
- tags: ['test'],
- startedAt: new Date(),
- rule: {
- id: ruleId,
- name: 'test rule',
- ruleTypeId: 'observability.test.fake',
- ruleTypeName: 'test',
- consumer: 'observability',
- producer: 'observability.test',
- },
- services: {
- alertFactory: getMockAlertFactory(),
- shouldWriteAlerts: sinon.stub().returns(true),
- getMaintenanceWindowIds: async () => [],
- },
- flappingSettings: {
- enabled: false,
- lookBackWindow: 20,
- statusChangeThreshold: 4,
- },
- dataStreamAdapter,
- } as unknown as RuleExecutorOptions<
- MockRuleParams,
- WrappedLifecycleRuleState,
- { [x: string]: unknown },
- { [x: string]: unknown },
- string
- >;
-
- // Execute the rule the first time
- const executorResult = await executor(options);
- expect(executorResult.state.wrapped).to.eql({
- testObject: {
- host: { name: 'host-01' },
- id: 'host-01',
- values: [{ name: 'count', value: 1 }],
- },
- });
-
- const alertUuid = executorResult.state.trackedAlerts['host-01'].alertUuid;
- expect(alertUuid).to.be('uuid-1');
-
- // We need to refresh the index so the data is available for the next call
- await es.indices.refresh({ index: `${ruleDataClient.indexName}*` });
-
- // Execute again to ensure that we read the object and write it again with the updated state
- const nextExecutorResult = await executor({ ...options, state: executorResult.state });
- expect(nextExecutorResult.state.wrapped).to.eql({
- testObject: {
- host: { name: 'host-01' },
- id: 'host-01',
- values: [
- { name: 'count', value: 1 },
- { name: 'count', value: 2 },
- ],
- },
- });
-
- // Refresh again so we can query the data to check it was written properly
- await es.indices.refresh({ index: `${ruleDataClient.indexName}*` });
-
- // Use the ruleDataClient to read the results from the index
- const response = await ruleDataClient.getReader().search({
- body: {
- query: {
- bool: {
- filter: [
- {
- term: {
- [ALERT_UUID]: nextExecutorResult.state.trackedAlerts['host-01'].alertUuid,
- },
- },
- ],
- },
- },
- },
- });
- const source = response.hits.hits[0]._source as any;
-
- // The state in Elasticsearch should match the state returned from the executor
- expect(source.testObject).to.eql(
- nextExecutorResult.state.wrapped && nextExecutorResult.state.wrapped.testObject
- );
- });
- });
-}
diff --git a/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/ess.config.ts b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/ess.config.ts
new file mode 100644
index 0000000000000..bee23188b35a7
--- /dev/null
+++ b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/ess.config.ts
@@ -0,0 +1,22 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import { FtrConfigProviderContext } from '@kbn/test';
+
+export default async function ({ readConfigFile }: FtrConfigProviderContext) {
+ const functionalConfig = await readConfigFile(
+ require.resolve('../../../../../config/ess/config.base.edr_workflows.trial')
+ );
+
+ return {
+ ...functionalConfig.getAll(),
+ testFiles: [require.resolve('..')],
+ junit: {
+ reportName: 'EDR Workflows API - Policy Tests - ESS Env - Trial License',
+ },
+ };
+}
diff --git a/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/serverless.config.ts b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/serverless.config.ts
new file mode 100644
index 0000000000000..ea2e2ce875ad1
--- /dev/null
+++ b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/configs/serverless.config.ts
@@ -0,0 +1,22 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import { FtrConfigProviderContext } from '@kbn/test';
+
+export default async function ({ readConfigFile }: FtrConfigProviderContext) {
+ const functionalConfig = await readConfigFile(
+ require.resolve('../../../../../config/serverless/config.base.edr_workflows')
+ );
+
+ return {
+ ...functionalConfig.getAll(),
+ testFiles: [require.resolve('..')],
+ junit: {
+ reportName: 'EDR Workflows API - Policy Tests - Serverless Env - Complete',
+ },
+ };
+}
diff --git a/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/datastream_index_creation.ts b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/datastream_index_creation.ts
new file mode 100644
index 0000000000000..bc029369f3fe4
--- /dev/null
+++ b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/datastream_index_creation.ts
@@ -0,0 +1,133 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+
+import expect from '@kbn/expect';
+import {
+ DEFAULT_DIAGNOSTIC_INDEX_PATTERN,
+ ENDPOINT_ACTION_RESPONSES_DS,
+ ENDPOINT_HEARTBEAT_INDEX_PATTERN,
+} from '@kbn/security-solution-plugin/common/endpoint/constants';
+import { buildIndexNameWithNamespace } from '@kbn/security-solution-plugin/common/endpoint/utils/index_name_utilities';
+import {
+ updateAgentPolicy,
+ updateIntegrationPolicy,
+} from '@kbn/security-solution-plugin/scripts/endpoint/common/fleet_services';
+import { PolicyTestResourceInfo } from '../../../../../security_solution_endpoint/services/endpoint_policy';
+import { FtrProviderContext } from '../../../../ftr_provider_context_edr_workflows';
+
+export default function ({ getService }: FtrProviderContext) {
+ const endpointPolicyTestResources = getService('endpointPolicyTestResources');
+ const esClient = getService('es');
+ const kbnClient = getService('kibanaServer');
+ const log = getService('log');
+ const retry = getService('retry');
+ const config = getService('config');
+ const isServerless = config.get('serverless');
+
+ // FIXME:PT Remove @skipInServerlessMKI and enable it for MKI
+ describe('@ess @serverless @skipInServerlessMKI Creation of DOT indices for elastic defend policies', function () {
+ let testData: PolicyTestResourceInfo;
+
+ const getExpectedIndexList = (namespace: string): string[] => {
+ const indexList = [
+ buildIndexNameWithNamespace(ENDPOINT_ACTION_RESPONSES_DS, namespace),
+ buildIndexNameWithNamespace(DEFAULT_DIAGNOSTIC_INDEX_PATTERN, namespace),
+ ];
+
+ if (isServerless) {
+ indexList.push(buildIndexNameWithNamespace(ENDPOINT_HEARTBEAT_INDEX_PATTERN, namespace));
+ }
+
+ return indexList;
+ };
+
+ beforeEach(async () => {
+ testData = await endpointPolicyTestResources.createPolicy({
+ // Endpoint policy inherits namespace from Agent policy
+ integrationPolicyOverrides: { namespace: undefined },
+ });
+ });
+
+ afterEach(async () => {
+ if (testData) {
+ await testData.cleanup();
+ // @ts-expect-error
+ testData = undefined;
+ }
+ });
+
+ it('should create indices when endpoint integration policy is created', async () => {
+ for (const indexName of getExpectedIndexList('default')) {
+ log.debug(`Checking that [${indexName}] exists`);
+ // The creation of the indices is done in the background and may not be done by
+ // the time the API call that created/updated the policy in fleet is returned - thus
+ // we use retry logic below
+ await retry.try(async () => {
+ expect(await esClient.indices.exists({ index: indexName })).to.be(true);
+ });
+ }
+ });
+
+ it('should create new indices when endpoint policy is updated with new namespace', async () => {
+ const namespace = Math.random().toString(32).substring(2);
+ await updateIntegrationPolicy(kbnClient, testData.packagePolicy.id, { namespace }, true);
+
+ for (const indexName of getExpectedIndexList(namespace)) {
+ log.debug(`Checking that [${indexName}] exists`);
+ await retry.try(async () => {
+ expect(await esClient.indices.exists({ index: indexName })).to.be(true);
+ });
+ }
+ });
+
+ it('should create new indices when agent policy is updated with new namespace', async () => {
+ const namespace = Math.random().toString(32).substring(2);
+ await updateAgentPolicy(kbnClient, testData.agentPolicy.id, { namespace }, true);
+
+ for (const indexName of getExpectedIndexList(namespace)) {
+ log.debug(`Checking that [${indexName}] exists`);
+ await retry.try(async () => {
+ expect(await esClient.indices.exists({ index: indexName })).to.be(true);
+ });
+ }
+ });
+
+ it('should NOT create indices when agent policy is updated if endpoint policy explicitly has a namespace defined', async () => {
+ const namespace = Math.random().toString(32).substring(2);
+ await updateIntegrationPolicy(kbnClient, testData.packagePolicy.id, { namespace }, true);
+
+ for (const indexName of getExpectedIndexList(namespace)) {
+ log.debug(`Checking that [${indexName}] exists`);
+ await retry.try(async () => {
+ expect(await esClient.indices.exists({ index: indexName })).to.be(true);
+ });
+ }
+
+ // Now update agent policy with new namespace and check that indices are NOT created
+ const namespace2 = Math.random().toString(32).substring(2);
+ await updateAgentPolicy(kbnClient, testData.agentPolicy.id, { namespace: namespace2 }, true);
+
+ // Delay just a few seconds to ensure policy index logic has executed
+ await new Promise(async (resolve, reject) => {
+ try {
+ setTimeout(() => {
+ resolve(undefined);
+ }, 5000);
+ } catch (error) {
+ reject(error);
+ }
+ });
+
+ for (const indexName of getExpectedIndexList(namespace2)) {
+ log.debug(`Checking that [${indexName}] does NOT exists`);
+ await retry.try(async () => {
+ expect(await esClient.indices.exists({ index: indexName })).to.be(false);
+ });
+ }
+ });
+ });
+}
diff --git a/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/index.ts b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/index.ts
new file mode 100644
index 0000000000000..dba8ed191925e
--- /dev/null
+++ b/x-pack/test/security_solution_api_integration/test_suites/edr_workflows/policy/trial_license_complete_tier/index.ts
@@ -0,0 +1,56 @@
+/*
+ * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
+ * or more contributor license agreements. Licensed under the Elastic License
+ * 2.0; you may not use this file except in compliance with the Elastic License
+ * 2.0.
+ */
+import { getRegistryUrl as getRegistryUrlFromIngest } from '@kbn/fleet-plugin/server';
+import { isServerlessKibanaFlavor } from '@kbn/security-solution-plugin/common/endpoint/utils/kibana_status';
+import { FtrProviderContext } from '../../../../ftr_provider_context_edr_workflows';
+import { ROLE } from '../../../../config/services/security_solution_edr_workflows_roles_users';
+
+export default function endpointAPIIntegrationTests(providerContext: FtrProviderContext) {
+ const { loadTestFile, getService } = providerContext;
+
+ describe('Endpoint Policy', function () {
+ const ingestManager = getService('ingestManager');
+ const rolesUsersProvider = getService('rolesUsersProvider');
+ const kbnClient = getService('kibanaServer');
+ const log = getService('log');
+ const endpointRegistryHelpers = getService('endpointRegistryHelpers');
+
+ const roles = Object.values(ROLE);
+ before(async () => {
+ if (!endpointRegistryHelpers.isRegistryEnabled()) {
+ log.warning('These tests are being run with an external package registry');
+ }
+
+ const registryUrl =
+ endpointRegistryHelpers.getRegistryUrlFromTestEnv() ?? getRegistryUrlFromIngest();
+ log.info(`Package registry URL for tests: ${registryUrl}`);
+ try {
+ await ingestManager.setup();
+ } catch (err) {
+ log.warning(`Error setting up ingestManager: ${err}`);
+ }
+
+ if (!(await isServerlessKibanaFlavor(kbnClient))) {
+ // create role/user
+ for (const role of roles) {
+ await rolesUsersProvider.createRole({ predefinedRole: role });
+ await rolesUsersProvider.createUser({ name: role, roles: [role] });
+ }
+ }
+ });
+
+ after(async () => {
+ if (!(await isServerlessKibanaFlavor(kbnClient))) {
+ // delete role/user
+ await rolesUsersProvider.deleteUsers(roles);
+ await rolesUsersProvider.deleteRoles(roles);
+ }
+ });
+
+ loadTestFile(require.resolve('./datastream_index_creation'));
+ });
+}
diff --git a/x-pack/test/security_solution_endpoint/services/endpoint_policy.ts b/x-pack/test/security_solution_endpoint/services/endpoint_policy.ts
index 335328db08ce4..8f24f116ca875 100644
--- a/x-pack/test/security_solution_endpoint/services/endpoint_policy.ts
+++ b/x-pack/test/security_solution_endpoint/services/endpoint_policy.ts
@@ -27,19 +27,19 @@ import { pkgKeyFromPackageInfo } from '@kbn/fleet-plugin/public/services/pkg_key
import { EndpointError } from '@kbn/security-solution-plugin/common/endpoint/errors';
import { FtrProviderContext } from '../configs/ftr_provider_context';
-const INGEST_API_ROOT = '/api/fleet';
-const INGEST_API_AGENT_POLICIES = `${INGEST_API_ROOT}/agent_policies`;
-const INGEST_API_AGENT_POLICIES_DELETE = `${INGEST_API_AGENT_POLICIES}/delete`;
-const INGEST_API_PACKAGE_POLICIES = `${INGEST_API_ROOT}/package_policies`;
-const INGEST_API_PACKAGE_POLICIES_DELETE = `${INGEST_API_PACKAGE_POLICIES}/delete`;
+const FLEET_API_ROOT = '/api/fleet';
+const FLEET_API_AGENT_POLICIES = `${FLEET_API_ROOT}/agent_policies`;
+const FLEET_API_AGENT_POLICIES_DELETE = `${FLEET_API_AGENT_POLICIES}/delete`;
+const FLEET_API_PACKAGE_POLICIES = `${FLEET_API_ROOT}/package_policies`;
+const FLEET_API_PACKAGE_POLICIES_DELETE = `${FLEET_API_PACKAGE_POLICIES}/delete`;
/**
* Holds information about the test resources created to support an Endpoint Policy
*/
export interface PolicyTestResourceInfo {
- /** The Ingest agent policy created */
+ /** The Fleet agent policy created */
agentPolicy: Immutable;
- /** The Ingest Package Policy created and added to agent policy.
+ /** The Fleet Package Policy created and added to agent policy.
* This is where Endpoint Policy is stored.
*/
packagePolicy: Immutable;
@@ -87,7 +87,7 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
.expect(200)
.catch((error) => {
return logSupertestApiErrorAndThrow(
- `Unable to retrieve Endpoint package via Ingest!`,
+ `Unable to retrieve Endpoint package via Fleet!`,
error
);
})
@@ -139,7 +139,7 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
let fullAgentPolicy: GetFullAgentPolicyResponse['item'];
try {
const apiResponse: { body: GetFullAgentPolicyResponse } = await supertest
- .get(`${INGEST_API_AGENT_POLICIES}/${agentPolicyId}/full`)
+ .get(`${FLEET_API_AGENT_POLICIES}/${agentPolicyId}/full`)
.expect(200);
fullAgentPolicy = apiResponse.body.item;
@@ -151,10 +151,16 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
},
/**
- * Creates an Ingest Agent policy and adds to it the Endpoint Package Policy that
+ * Creates a Fleet Agent policy and adds to it the Endpoint Package Policy that
* stores the Policy configuration data
*/
- async createPolicy(): Promise {
+ async createPolicy({
+ agentPolicyOverrides = {},
+ integrationPolicyOverrides = {},
+ }: Partial<{
+ agentPolicyOverrides: Partial;
+ integrationPolicyOverrides: Partial;
+ }> = {}): Promise {
// create Agent Policy
let agentPolicy: CreateAgentPolicyResponse['item'];
try {
@@ -162,15 +168,16 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
name: `East Coast ${uuidv4()}`,
description: 'East Coast call center',
namespace: 'default',
+ ...agentPolicyOverrides,
};
const { body: createResponse }: { body: CreateAgentPolicyResponse } = await supertest
- .post(INGEST_API_AGENT_POLICIES)
+ .post(FLEET_API_AGENT_POLICIES)
.set('kbn-xsrf', 'xxx')
.send(newAgentPolicyData)
.expect(200);
agentPolicy = createResponse.item;
} catch (error) {
- return logSupertestApiErrorAndThrow(`Unable to create Agent Policy via Ingest!`, error);
+ return logSupertestApiErrorAndThrow(`Unable to create Agent Policy via Fleet!`, error);
}
// Retrieve the Endpoint package information
@@ -210,15 +217,16 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
title: endpointPackageInfo?.title ?? '',
version: endpointPackageInfo?.version ?? '',
},
+ ...integrationPolicyOverrides,
};
const { body: createResponse }: { body: CreatePackagePolicyResponse } = await supertest
- .post(INGEST_API_PACKAGE_POLICIES)
+ .post(FLEET_API_PACKAGE_POLICIES)
.set('kbn-xsrf', 'xxx')
.send(newPackagePolicyData)
.expect(200);
packagePolicy = createResponse.item;
} catch (error) {
- return logSupertestApiErrorAndThrow(`Unable to create Package Policy via Ingest!`, error);
+ return logSupertestApiErrorAndThrow(`Unable to create Package Policy via Fleet!`, error);
}
log.info(
@@ -237,12 +245,16 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
packagePolicyIds: [packagePolicy.id],
};
await supertest
- .post(INGEST_API_PACKAGE_POLICIES_DELETE)
+ .post(FLEET_API_PACKAGE_POLICIES_DELETE)
.set('kbn-xsrf', 'xxx')
.send(deletePackagePolicyData)
.expect(200);
+ log.info(`Fleet Endpoint integration policy deleted: ${packagePolicy.id}`);
} catch (error) {
- logSupertestApiErrorAndThrow('Unable to delete Package Policy via Ingest!', error);
+ logSupertestApiErrorAndThrow(
+ `Unable to delete Endpoint Integration Policy [${packagePolicy.id}] via Fleet!`,
+ error
+ );
}
// Delete Agent Policy
@@ -251,12 +263,16 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
agentPolicyId: agentPolicy.id,
};
await supertest
- .post(INGEST_API_AGENT_POLICIES_DELETE)
+ .post(FLEET_API_AGENT_POLICIES_DELETE)
.set('kbn-xsrf', 'xxx')
.send(deleteAgentPolicyData)
.expect(200);
+ log.info(`Fleet Agent policy deleted: ${agentPolicy.id}`);
} catch (error) {
- logSupertestApiErrorAndThrow('Unable to delete Agent Policy via Ingest!', error);
+ logSupertestApiErrorAndThrow(
+ `Unable to delete Agent Policy [${agentPolicy.id}] via Fleet!`,
+ error
+ );
}
},
};
@@ -271,7 +287,7 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
try {
const { body: packagePoliciesResponse }: { body: GetPackagePoliciesResponse } =
await supertest
- .get(INGEST_API_PACKAGE_POLICIES)
+ .get(FLEET_API_PACKAGE_POLICIES)
.set('kbn-xsrf', 'xxx')
.query({ kuery: `${PACKAGE_POLICY_SAVED_OBJECT_TYPE}.name: ${name}` })
.send()
@@ -297,12 +313,12 @@ export function EndpointPolicyTestResourcesProvider({ getService }: FtrProviderC
packagePolicyIds: [packagePolicyList[0].id],
};
await supertest
- .post(INGEST_API_PACKAGE_POLICIES_DELETE)
+ .post(FLEET_API_PACKAGE_POLICIES_DELETE)
.set('kbn-xsrf', 'xxx')
.send(deletePackagePolicyData)
.expect(200);
} catch (error) {
- logSupertestApiErrorAndThrow('Unable to delete Package Policy via Ingest!', error);
+ logSupertestApiErrorAndThrow('Unable to delete Package Policy via Fleet!', error);
}
},
};
diff --git a/yarn.lock b/yarn.lock
index 9141268d56269..57ffec1e0a278 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -7429,7 +7429,7 @@
"@launchdarkly/js-sdk-common" "2.11.0"
semver "7.5.4"
-"@launchdarkly/node-server-sdk@^9.6.1":
+"@launchdarkly/node-server-sdk@^9.7.0":
version "9.7.0"
resolved "https://registry.yarnpkg.com/@launchdarkly/node-server-sdk/-/node-server-sdk-9.7.0.tgz#87223c2d3ab5fc7186065a0974960c94f73573ad"
integrity sha512-ABOsjcjH9pFdyG1m5++lhP+ngxfx4GMcIfgTp0iSPncuh0dMxCCWSx831gbhxR9M+f2x4EnsQ9HEdwnmwktb9g==
@@ -14239,10 +14239,10 @@ chrome-trace-event@^1.0.2:
dependencies:
tslib "^1.9.0"
-chromedriver@^129.0.0:
- version "129.0.1"
- resolved "https://registry.yarnpkg.com/chromedriver/-/chromedriver-129.0.1.tgz#4a7215f57c419e87468f04f3b011db51e6bc80fc"
- integrity sha512-thJqK3c7p9rIhmjBvs/cgaK0Hk30g7LbnmMXQ2aLnn75ZOiEl/2GBcgc6fw+4GIw1SmOYhnNmaEI1iTP3qob0w==
+chromedriver@^130.0.1:
+ version "130.0.1"
+ resolved "https://registry.yarnpkg.com/chromedriver/-/chromedriver-130.0.1.tgz#24fd5b2c9c9df4ebfc5d28c94eca8658915fbe15"
+ integrity sha512-JH+OxDZ7gVv02r9oXwj4mQ8JCtj62g0fCD1LMUUYdB/4mPxn/E2ys+1IzXItoE7vXM9fGVc9R1akvXLqwwuSww==
dependencies:
"@testim/chrome-version" "^1.1.4"
axios "^1.7.4"
@@ -18755,10 +18755,10 @@ gcp-metadata@^6.1.0:
gaxios "^6.0.0"
json-bigint "^1.0.0"
-geckodriver@^4.4.4:
- version "4.4.4"
- resolved "https://registry.yarnpkg.com/geckodriver/-/geckodriver-4.4.4.tgz#0aad02533e8cf127573f4d86f1cc5450c913f095"
- integrity sha512-0zaw19tcmWeluqx7+Y559JGBtidu1D0Lb8ElYKiNEQu8r3sCfrLUf5V10xypl8u29ZLbgRV7WflxCJVTCkCMFA==
+geckodriver@^4.5.1:
+ version "4.5.1"
+ resolved "https://registry.yarnpkg.com/geckodriver/-/geckodriver-4.5.1.tgz#624fc01815c1aa498dd3f717f7bd4c6cca0c57b8"
+ integrity sha512-lGCRqPMuzbRNDWJOQcUqhNqPvNsIFu6yzXF8J/6K3WCYFd2r5ckbeF7h1cxsnjA7YLSEiWzERCt6/gjZ3tW0ug==
dependencies:
"@wdio/logger" "^9.0.0"
"@zip.js/zip.js" "^2.7.48"
@@ -22183,18 +22183,18 @@ launchdarkly-eventsource@2.0.3:
resolved "https://registry.yarnpkg.com/launchdarkly-eventsource/-/launchdarkly-eventsource-2.0.3.tgz#8a7b8da5538153f438f7d452b1c87643d900f984"
integrity sha512-VhFjppK7jXlcEKaS7bxdoibB5j01NKyeDR7a8XfssdDGNWCTsbF0/5IExSmPi44eDncPhkoPNxlSZhEZvrbD5w==
-launchdarkly-js-client-sdk@^3.4.0:
- version "3.4.0"
- resolved "https://registry.yarnpkg.com/launchdarkly-js-client-sdk/-/launchdarkly-js-client-sdk-3.4.0.tgz#5b5959b548edac8a0f368eb40b079d942573d37b"
- integrity sha512-3v1jKy1RECT0SG/3SGlyRO32vweoNxvWiJuIChRh/Zhk98cHpANuwameXVhwJ4WEDNZJTur73baaKAyatSP46A==
+launchdarkly-js-client-sdk@^3.5.0:
+ version "3.5.0"
+ resolved "https://registry.yarnpkg.com/launchdarkly-js-client-sdk/-/launchdarkly-js-client-sdk-3.5.0.tgz#cb0e3d6fc21e56750aa86fcaf75733d7f510946f"
+ integrity sha512-3dgxC9S8K2ix6qjdArjZGOJPtAytgfQTuE+vWgjWJK7725rpYbuqbHghIFr5B0+WyWyVBYANldjWd1JdtYLwsw==
dependencies:
escape-string-regexp "^4.0.0"
- launchdarkly-js-sdk-common "5.3.0"
+ launchdarkly-js-sdk-common "5.4.0"
-launchdarkly-js-sdk-common@5.3.0:
- version "5.3.0"
- resolved "https://registry.yarnpkg.com/launchdarkly-js-sdk-common/-/launchdarkly-js-sdk-common-5.3.0.tgz#336a54843f5ba3541632e10014e49dff45d41674"
- integrity sha512-NI5wFF8qhjtpRb4KelGdnwNIOf/boLlbLiseV7uf1jxSeoM/L30DAz87RT8VhYCSGCo4LedGILQFednI/MKFkA==
+launchdarkly-js-sdk-common@5.4.0:
+ version "5.4.0"
+ resolved "https://registry.yarnpkg.com/launchdarkly-js-sdk-common/-/launchdarkly-js-sdk-common-5.4.0.tgz#c9787daebe0b583b01d2334218524ea142c85001"
+ integrity sha512-Kb3SDcB6S0HUpFNBZgtEt0YUV/fVkyg+gODfaOCJQ0Y0ApxLKNmmJBZOrPE2qIdzw536u4BqEjtaJdqJWCEElg==
dependencies:
base64-js "^1.3.0"
fast-deep-equal "^2.0.1"